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


Posted in PHP onJune 29, 2013

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

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

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

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

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

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

PHP 相关文章推荐
实现 win2003 下 mysql 数据库每天自动备份
Dec 06 PHP
THINKPHP+JS实现缩放图片式截图的实现
Mar 07 PHP
PHP 魔术函数使用说明
May 14 PHP
PHP中的float类型使用说明
Jul 27 PHP
PHP安全技术之 实现php基本安全
Sep 04 PHP
解析php中session的实现原理以及大网站应用应注意的问题
Jun 17 PHP
mac下安装nginx和php
Nov 04 PHP
php文件压缩之PHPZip类用法实例
Jun 18 PHP
php检测图片主要颜色的方法
Jul 01 PHP
轻松掌握php设计模式之访问者模式
Sep 23 PHP
PHP SESSION跨页面传递失败解决方案
Dec 11 PHP
laravel与thinkphp之间的区别与优缺点
Mar 02 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
德生PL990的分析评价
2021/03/02 无线电
简单的php写入数据库类代码分享
2011/07/26 PHP
基于wordpress主题制作的具体实现步骤
2013/05/10 PHP
PHP使用array_multisort对多个数组或多维数组进行排序
2014/12/16 PHP
php+mysqli实现批量替换数据库表前缀的方法
2014/12/29 PHP
vmware linux系统安装最新的php7图解
2019/04/14 PHP
快速排序 php与javascript的不同之处
2011/02/22 Javascript
JavaScript中的变量声明早于赋值分析
2012/03/01 Javascript
载入jQuery库的最佳方法详细说明及实现代码
2012/12/28 Javascript
jQuery点击弹出下拉菜单的小例子
2013/08/01 Javascript
jQuery快速上手:写jQuery与直接写JS的区别详细解析
2013/08/26 Javascript
javascript限制文本框输入值类型的方法
2015/05/07 Javascript
Vue.js教程之计算属性
2016/11/11 Javascript
总结几道关于Node.js的面试问题
2017/01/11 Javascript
ReactNative页面跳转Navigator实现的示例代码
2017/08/02 Javascript
使用puppeteer破解极验的滑动验证码
2018/02/24 Javascript
详解在React中跨组件分发状态的三种方法
2018/08/09 Javascript
jQuery实现动态添加和删除input框代码实例
2019/03/29 jQuery
解决layer.msg 不居中 ifram中的问题
2019/09/05 Javascript
通过js随机函数Math.random实现乱序
2020/05/19 Javascript
封装 axios+promise通用请求函数操作
2020/08/11 Javascript
[20:46]Ti4循环赛第三日VG vs DK
2014/07/12 DOTA
[35:34]Liquid vs Winstrike 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
详解JavaScript编程中的window与window.screen对象
2015/10/26 Python
Python装饰器模式定义与用法分析
2018/08/06 Python
python实现生成字符串大小写字母和数字的各种组合
2019/01/01 Python
python实现井字棋小游戏
2020/03/04 Python
python实现TCP文件传输
2020/03/20 Python
HTML5到底会有什么发展?HTML5的前景展望
2015/07/07 HTML / CSS
日语求职信范文
2013/12/17 职场文书
先进事迹报告会主持词
2014/04/02 职场文书
学校百日安全生产活动总结
2014/07/05 职场文书
2014基层党员批评与自我批评范文
2014/09/24 职场文书
火锅店的开业营销方案范本!
2019/07/05 职场文书
python 中的@运算符使用
2021/05/26 Python
Java 数组的使用
2022/05/11 Java/Android