浅谈web上存漏洞及原理分析、防范方法(安全文件上存方法)
2015-01-24信息快讯网
我们知道,上存漏洞常见有,文件名检测漏洞,还有就是文件格式检查漏洞。 另外还有个一个,就是保存文件存在漏洞
这类漏洞,主要是可以读取用户传入路径名称,采用不正确的过滤方法,导致恶意用户,将文件上存到非预期的地方,带来安全隐患。其实,我们抓住几个地方即可,我们先来分析下,既然用户要上存文件,而且文件将是多种多样格式;可能有的文件内容与用户传入格式不一致,有的文件内容还夹杂木马代码。 那么,我们让用户上存文件,跟站点文件做一个分别授权,做隔离。
让保存上存目录独立开来,目录权限只读不能执行
这一步从系统设计加以授权,无论你上次什么文件,都不可能执行到。就算我不做任何检测,你的文件都上存到这里了,也不会对我系统构成安全。(如果有用户上存一些反动言语的图片,那另外需要处理的)
不直接使用服务器传入值,所有都要进行检测
这类跟我们做一切输入都是有害原则一样,对于客户端传入的:type, name ,都要进行判断,不直接使用。对于要生成到某个目录,某个文件名。
文件名最好方法是:自己写死目录(不要读取传入目录),文件名,最好自己随机生成,不读取用户文件名。文件扩展名,可以取最右边”.”后面字符。
以上2个方法,刚好从2个方面对上存做了整体约束。
方法2 : 保存上存文件名,按照自己指定目录写入,并且文件名自己生成的。
方法1:只要保证文件写对了位置,然后从配置上,对写入目录进行权限控制,这个是治本。可以做到,你无论上存什么文件,都让你没有权限跳出去可以运行。
以上2个方法,一起使用,可以保证文件正确存到地方,然后,权限可以控制。 这里顺便说明下, 判断用户上存文件是否满足要求类型,就直接检查文件扩展名,只要满足扩展名就让上存。 反正,做了执行权限限制,你不按要求上存内容,也无妨。 反正,不能执行,也不会有多大危害性的。
正确步骤:
1.读取文件名,验证扩展名是不是在范围内
2.自己定义生成的文件名,目录,扩展名可以来自文件名扩展名。 其它值,都自己配置,不读取上存中内容
3.将文件 移到新目录(这个目录权限设置只读)
好了,以上是一般操作方法,希望对大家有帮助,也欢迎朋友们交流!也希望提供更好的方法!接下来,我会在web 开发中,常见一些方法功能安全设计方面继续写一些我的心得,看法!
使用PHP生成二维码的两种方法(带logo图像)
zf框架的zend_cache缓存使用方法(zend框架)
PHP判断指定时间段的2个方法
3个PHP多维数组转为一维数组的方法实例
PHP四大安全策略
php实现快速排序的三种方法分享
php遍历文件夹和文件列表示例分享
php获取文件夹路径内的图片以及分页显示示例
php设置允许大文件上传示例代码
php如何解决无法上传大于8M的文件问题
PHP文件大小格式化函数合集
PHP程序漏洞产生的原因分析与防范方法说明
php中sql注入漏洞示例 sql注入漏洞修复
php漏洞之跨网站请求伪造与防止伪造方法
php防注入及开发安全详细解析
PHP 线程安全与非线程安全版本的区别深入解析
PHP 安全检测代码片段(分享)
浅谈web上存漏洞及原理分析、防范方法(文件名检测漏洞)
探讨:web上存漏洞及原理分析、防范方法
解析web文件操作常见安全漏洞(目录、文件名检测漏洞)
浅析Dos下运行php.exe,出现没有找到php_mbstring.dll 错误的解决方法
解析curl提交GET,POST,Cookie的简单方法
php selectradio和checkbox默认选择的实现方法详解
php获取数组中重复数据的两种方法
关于url地址传参数时字符串有回车造成页面脚本赋值失败的解决方法
深入apache配置文件httpd.conf的部分参数说明
PHP遍历某个目录下的所有文件和子文件夹的实现代码
基于php常用函数总结(数组,字符串,时间,文件操作)
php 批量生成html,txt文件的实现代码
解析php安全性问题中的:Null 字符问题
PHP与MongoDB简介|安全|M+PHP应用实例详解
编写安全 PHP应用程序的七个习惯深入分析
基于PHP开发中的安全防范知识详解
PHP漏洞全解(详细介绍)