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


Posted in PHP onJune 29, 2013

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

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

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

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

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

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

PHP 相关文章推荐
PHP中的cookie
Nov 26 PHP
php str_pad() 将字符串填充成指定长度的字符串
Feb 23 PHP
解析func_num_args与func_get_args函数的使用
Jun 24 PHP
Codeigniter生成Excel文档的简单方法
Jun 12 PHP
php中字符集转换iconv函数使用总结
Oct 11 PHP
浅谈PHP正则表达式中修饰符/i, /is, /s, /isU
Oct 21 PHP
php绘制圆形的方法
Jan 24 PHP
php单例模式示例分享
Feb 12 PHP
PHP中多线程的两个实现方法
Oct 14 PHP
PHP实现的折半查找算法示例
Dec 19 PHP
laravel 时间格式转时间戳的例子
Oct 11 PHP
Laravel 类和接口注入相关的代码
Oct 15 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
无线电广播与收音机发展的历史回眸
2021/03/02 无线电
咖啡磨器 如何选购一台适合家用的意式磨豆机
2021/03/05 新手入门
PHP学习资料汇总与网址
2007/03/16 PHP
php面向对象全攻略 (六)__set() __get() __isset() __unset()的用法
2009/09/30 PHP
PHP 开发环境配置(Zend Studio)
2010/04/28 PHP
PHP判断是否微信访问的方法示例
2019/03/27 PHP
改善用户体验的五款jQuery插件分享
2011/05/22 Javascript
工作需要写的一个js拖拽组件
2011/07/28 Javascript
jquery学习总结(超级详细)
2014/09/04 Javascript
jQuery统计上传文件大小的方法
2015/01/24 Javascript
JS常见问题之为什么点击弹出的i总是最后一个
2016/01/05 Javascript
canvas实现简易的圆环进度条效果
2017/02/28 Javascript
详解webpack 入门总结和实践(按需异步加载,css单独打包,生成多个入口文件)
2017/06/20 Javascript
这15个Vue指令,让你的项目开发爽到爆
2019/10/11 Javascript
JS简易计算器实例讲解
2020/06/30 Javascript
react ant Design手动设置表单的值操作
2020/10/31 Javascript
[01:13]DOTA2群星解读国服召集令 一起说出回归的理由
2013/07/17 DOTA
[40:16]TFT vs Mski Supermajor小组赛C组 BO3 第二场 6.3
2018/06/04 DOTA
在Python中处理字符串之ljust()方法的使用简介
2015/05/19 Python
解决python2.7 查询mysql时出现中文乱码
2016/10/09 Python
python中import学习备忘笔记
2017/01/24 Python
python使用matplotlib绘制柱状图教程
2017/02/08 Python
python  Django中的apps.py的目的是什么
2018/10/15 Python
python 制作自定义包并安装到系统目录的方法
2018/10/27 Python
使用PyQt4 设置TextEdit背景的方法
2019/06/14 Python
Pytorch 神经网络—自定义数据集上实现教程
2020/01/07 Python
python进度条显示之tqmd模块
2020/08/22 Python
Python3实现英文字母转换哥特式字体实例代码
2020/09/01 Python
全网最详细的PyCharm+Anaconda的安装过程图解
2021/01/25 Python
汽车工程专业应届生求职信
2013/10/19 职场文书
触摸春天教学反思
2014/02/03 职场文书
教师政风行风自查自纠报告
2014/10/21 职场文书
企业开业庆典答谢词
2015/01/20 职场文书
个人自荐书范文
2015/03/09 职场文书
基于python定位棋子位置及识别棋子颜色
2021/07/26 Python
「回转企鹅罐」10周年纪念展「輪るピングドラム展」海报公开
2022/03/22 日漫