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


Posted in PHP onJune 29, 2013

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

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

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

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

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

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

PHP 相关文章推荐
PHP数据库操作面向对象的优点
Oct 09 PHP
PHP的中问验证码
Nov 25 PHP
php中在PDO中使用事务(Transaction)
May 14 PHP
php5.5中类级别的常量使用介绍
Oct 02 PHP
php获取目标函数执行时间示例
Mar 04 PHP
PHP的password_hash()使用实例
Mar 17 PHP
PHP如何实现Unicode和Utf-8编码相互转换
Jul 29 PHP
非常重要的php正则表达式详解
Jan 04 PHP
php强制下载文件函数
Aug 24 PHP
php中实现进程锁与多进程的方法
Sep 18 PHP
PHP面向对象程序设计高级特性详解(接口,继承,抽象类,析构,克隆等)
Dec 02 PHP
php fread函数使用方法总结
May 28 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教程孙仲岳主讲
2008/01/07 PHP
PHP连接局域网MYSQL数据库的简单实例
2013/08/26 PHP
php+ajax实时刷新简单实例
2015/02/25 PHP
CodeIgniter针对lighttpd服务器URL重写的方法
2015/06/10 PHP
Yii2.0多文件上传实例说明
2017/07/24 PHP
JavaScript isPrototypeOf和hasOwnProperty使用区别
2010/03/04 Javascript
使用Json比用string返回数据更友好,也更面向对象一些
2011/09/13 Javascript
javascript中自定义对象的属性方法分享
2013/07/12 Javascript
Jquery 复选框取值兼容FF和IE8(测试有效)
2013/10/29 Javascript
js中实现多态采用和继承类似的方法
2014/08/22 Javascript
js的toLowerCase方法用法实例
2015/01/27 Javascript
Javascript中call和apply函数的比较和使用实例
2015/02/03 Javascript
初识Node.js
2015/03/20 Javascript
JS选中checkbox后获取table内一行TD所有数据的方法
2015/07/01 Javascript
JS+CSS实现电子商务网站导航模板效果代码
2015/09/10 Javascript
js原生之焦点图转换加定时器实例
2016/12/12 Javascript
vue.js $refs和$emit 父子组件交互的方法
2017/12/20 Javascript
jQuery实现的两种简单弹窗效果示例
2018/04/18 jQuery
使用weixin-java-tools完成微信授权登录、微信支付的示例
2018/09/26 Javascript
详解小程序循环require之坑
2019/03/08 Javascript
JS桶排序的简单理解与实现方法示例
2019/11/25 Javascript
JS插入排序简单理解与实现方法分析
2019/11/25 Javascript
antd 表格列宽自适应方法以及错误处理操作
2020/10/27 Javascript
Windows下Anaconda2安装NLTK教程
2018/09/19 Python
python3利用ctypes传入一个字符串类型的列表方法
2019/02/12 Python
如何在python中实现随机选择
2019/11/02 Python
Python flask框架实现查询数据库并显示数据
2020/06/04 Python
Python celery原理及运行流程解析
2020/06/13 Python
详解anaconda安装步骤
2020/11/23 Python
旧时光糖果:Old Time Candy
2018/02/05 全球购物
印度民族服装购物网站:BIBA
2019/08/05 全球购物
Nobody Denim官网:购买高级女士牛仔裤
2021/03/15 全球购物
优秀少先队辅导员先进事迹材料
2014/05/18 职场文书
党校个人总结
2015/03/04 职场文书
浅谈mysql返回Boolean类型的几种情况
2021/06/04 MySQL
php png失真的原因及解决办法
2021/11/17 PHP