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


Posted in PHP onJune 29, 2013

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

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

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

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

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

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

PHP 相关文章推荐
PHP生成HTML静态页面实例代码
Aug 31 PHP
thinkphp3.0 模板中函数的使用
Nov 13 PHP
深入php list()函数的详解
Jun 05 PHP
yii实现图片上传及缩略图生成的方法
Dec 04 PHP
推荐十款免费 WordPress 插件
Mar 24 PHP
PHP 前加at符合@的作用解析
Jul 31 PHP
PHP处理会话函数大总结
Aug 05 PHP
PHP模拟asp中response类实现方法
Aug 08 PHP
浅析PHP 中move_uploaded_file 上传中文文件名失败
Apr 17 PHP
laravel框架的安装与路由实例分析
Oct 11 PHP
PHP常见的序列化与反序列化操作实例分析
Oct 28 PHP
php实现图片压缩处理
Sep 09 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实现将任意进制数转换成10进制的方法
2015/04/17 PHP
详解PHP中foreach的用法和实例
2016/10/25 PHP
php文件上传 你真的掌握了吗
2016/11/28 PHP
PHP数组array类常见操作示例
2020/05/15 PHP
让IE8支持DOM 2(不用框架!)
2009/12/31 Javascript
javaScript 利用闭包模拟对象的私有属性
2011/12/29 Javascript
jquery.Jwin.js 基于jquery的弹出层插件代码
2012/05/23 Javascript
JavaScript限定复选框的选择个数示例代码
2013/08/25 Javascript
基于JS实现的倒计时程序实例
2015/07/24 Javascript
js正则表达式replace替换变量方法
2016/05/21 Javascript
nodejs微信公众号支付开发
2016/09/19 NodeJs
在localStorage中存储对象数组并读取的方法
2016/09/24 Javascript
基于node.js依赖express解析post请求四种数据格式
2017/02/13 Javascript
jQuery实现的手风琴侧边菜单效果
2017/03/29 jQuery
为什么Vue3.0使用Proxy实现数据监听(defineProperty表示不背这个锅)
2019/10/14 Javascript
在vue+element ui框架里实现lodash的debounce防抖
2019/11/13 Javascript
vue中的循环对象属性和属性值用法
2020/09/04 Javascript
JavaScript本地储存:localStorage、sessionStorage、cookie的使用
2020/10/13 Javascript
[16:01]夜魇凡尔赛茶话会 第二期01:你比划我猜
2021/03/11 DOTA
Python 实现 贪吃蛇大作战 代码分享
2016/09/07 Python
python通过elixir包操作mysql数据库实例代码
2018/01/31 Python
python计算列表内各元素的个数实例
2018/06/29 Python
基于Python测试程序是否有错误
2020/05/16 Python
keras模型保存为tensorflow的二进制模型方式
2020/05/25 Python
德国体育用品网上商店:SC24.com
2016/08/01 全球购物
耐克巴西官方网站:Nike巴西
2016/08/14 全球购物
照片礼物和装饰:MyPhoto
2019/11/02 全球购物
20岁生日感言
2014/01/13 职场文书
市政施工员自我鉴定
2014/01/15 职场文书
青春励志演讲稿范文
2014/08/25 职场文书
个人四风对照检查材料
2014/09/26 职场文书
2015年宣传工作总结
2015/04/08 职场文书
上课迟到检讨书范文
2015/05/06 职场文书
奖学金主要事迹范文
2015/11/04 职场文书
初二物理教学反思
2016/02/19 职场文书
Win11电脑显示本地时间与服务器时间不一致怎么解决?
2022/04/05 数码科技