浅谈web上存漏洞及原理分析、防范方法(安全文件上存方法)


Posted in PHP onJune 29, 2013

这类漏洞,主要是可以读取用户传入路径名称,采用不正确的过滤方法,导致恶意用户,将文件上存到非预期的地方,带来安全隐患。

其实,我们抓住几个地方即可,我们先来分析下,既然用户要上存文件,而且文件将是多种多样格式;可能有的文件内容与用户传入格式不一致,有的文件内容还夹杂木马代码。 那么,我们让用户上存文件,跟站点文件做一个分别授权,做隔离。

让保存上存目录独立开来,目录权限只读不能执行
这一步从系统设计加以授权,无论你上次什么文件,都不可能执行到。就算我不做任何检测,你的文件都上存到这里了,也不会对我系统构成安全。(如果有用户上存一些反动言语的图片,那另外需要处理的)

不直接使用服务器传入值,所有都要进行检测
这类跟我们做一切输入都是有害原则一样,对于客户端传入的:type, name ,都要进行判断,不直接使用。对于要生成到某个目录,某个文件名。
文件名最好方法是:自己写死目录(不要读取传入目录),文件名,最好自己随机生成,不读取用户文件名。文件扩展名,可以取最右边”.”后面字符。
以上2个方法,刚好从2个方面对上存做了整体约束。
方法2 : 保存上存文件名,按照自己指定目录写入,并且文件名自己生成的。
方法1:只要保证文件写对了位置,然后从配置上,对写入目录进行权限控制,这个是治本。可以做到,你无论上存什么文件,都让你没有权限跳出去可以运行。

以上2个方法,一起使用,可以保证文件正确存到地方,然后,权限可以控制。 这里顺便说明下, 判断用户上存文件是否满足要求类型,就直接检查文件扩展名,只要满足扩展名就让上存。 反正,做了执行权限限制,你不按要求上存内容,也无妨。 反正,不能执行,也不会有多大危害性的。
正确步骤:
1.读取文件名,验证扩展名是不是在范围内
2.自己定义生成的文件名,目录,扩展名可以来自文件名扩展名。 其它值,都自己配置,不读取上存中内容
3.将文件 移到新目录(这个目录权限设置只读)

好了,以上是一般操作方法,希望对大家有帮助,也欢迎朋友们交流!也希望提供更好的方法!接下来,我会在web 开发中,常见一些方法功能安全设计方面继续写一些我的心得,看法!

PHP 相关文章推荐
php foreach 使用&(与运算符)引用赋值要注意的问题
Feb 16 PHP
php限制上传文件类型并保存上传文件的方法
Mar 13 PHP
使用URL传输SESSION信息
Jul 14 PHP
ThinkPHP函数详解之M方法和R方法
Sep 10 PHP
php基于Fleaphp框架实现cvs数据导入MySQL的方法
Feb 23 PHP
关于PHP通用返回值设置方法
Mar 31 PHP
php实现的二分查找算法示例
Jun 20 PHP
PHP实现批量重命名某个文件夹下所有文件的方法
Sep 04 PHP
详解PHP发送邮件知识点
May 06 PHP
关于php unset对json_encode的影响详解
Nov 14 PHP
php-fpm超时时间设置request_terminate_timeout资源问题分析
Sep 27 PHP
ThinkPHP5和ThinkPHP6的区别
Mar 31 PHP
解析web文件操作常见安全漏洞(目录、文件名检测漏洞)
Jun 29 #PHP
解析PHP中empty is_null和isset的测试
Jun 29 #PHP
浅析Dos下运行php.exe,出现没有找到php_mbstring.dll 错误的解决方法
Jun 29 #PHP
浅析PHP中的UNICODE 编码与解码
Jun 29 #PHP
基于flush()不能按顺序输出时的解决办法
Jun 29 #PHP
解析PHP 使用curl提交json格式数据
Jun 29 #PHP
PHP 过滤页面中的BOM(实现代码)
Jun 29 #PHP
You might like
PHP获取数组最后一个值的2种方法
2015/01/21 PHP
yii2中结合gridview如何使用modal弹窗实例代码详解
2016/06/12 PHP
phpcms配置列表页以及获得文章发布时间
2017/07/04 PHP
PHP面向对象程序设计继承用法简单示例
2018/12/28 PHP
PHP PDO和消息队列的个人理解与应用实例分析
2019/11/25 PHP
[原创]来自ImageSee官方 JavaScript图片浏览器
2008/01/16 Javascript
js修改input的type属性及浏览器兼容问题探讨与解决
2013/01/23 Javascript
Jquery中使用setInterval和setTimeout的方法
2013/04/08 Javascript
js判断滚动条是否已到页面最底部或顶部实例
2014/11/20 Javascript
javascript特殊日历控件分享
2016/03/07 Javascript
JS判断元素是否在数组内的实现代码
2016/03/30 Javascript
从零学习node.js之详解异步控制工具async(八)
2017/02/27 Javascript
JS中图片压缩的方法小结
2017/11/14 Javascript
Node.js + express实现上传大文件的方法分析【图片、文本文件】
2019/03/14 Javascript
JAVA面试题 static关键字详解
2019/07/16 Javascript
解决layer.confirm选择完之后消息框不消失的问题
2019/09/16 Javascript
JS动态图片的实现方法完整示例
2020/01/13 Javascript
vue webpack build资源相对路径的问题及解决方法
2020/06/04 Javascript
[01:20:37]FNATIC vs NIP 2019国际邀请赛小组赛 BO2 第一场 8.16
2019/08/19 DOTA
Python多进程multiprocessing用法实例分析
2017/08/18 Python
python利用正则表达式搜索单词示例代码
2017/09/24 Python
python在html中插入简单的代码并加上时间戳的方法
2018/10/16 Python
Python 仅获取响应头, 不获取实体的实例
2019/08/21 Python
pymysql模块的使用(增删改查)详解
2019/09/09 Python
Python读取配置文件(config.ini)以及写入配置文件
2020/04/08 Python
违反课堂纪律检讨书
2014/01/19 职场文书
聘用意向书范本
2014/04/01 职场文书
《陈涉世家》教学反思
2014/04/12 职场文书
商铺租房协议书范本
2014/12/04 职场文书
管理人员岗位职责
2015/02/14 职场文书
辞职信范文大全
2015/03/02 职场文书
高中开学感言
2015/08/01 职场文书
体育教师研修感悟
2015/11/18 职场文书
机关干部正风肃纪心得体会
2016/01/15 职场文书
MySQL开启事务的方式
2021/06/26 MySQL
springboot读取nacos配置文件
2022/05/20 Java/Android