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


Posted in PHP onJune 29, 2013

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

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

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

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

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

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

PHP 相关文章推荐
在mysql数据库原有字段后增加新内容
Nov 26 PHP
PHP json格式和js json格式 js跨域调用实现代码
Sep 08 PHP
利用PHP+JS实现搜索自动提示(实例)
Jun 09 PHP
PHP-Java-Bridge使用笔记
Sep 22 PHP
php实现从上传文件创建缩略图的方法
Apr 02 PHP
php 生成Tab键或逗号分隔的CSV
Sep 24 PHP
php实现的http请求封装示例
Nov 08 PHP
php+redis实现多台服务器内网存储session并读取示例
Jan 12 PHP
php生成图片缩略图功能示例
Feb 22 PHP
AJAX的使用方法详解
Apr 29 PHP
基于Laravel实现的用户动态模块开发
Sep 21 PHP
浅谈Laravel模板实体转义带来的坑
Oct 22 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下一个阿拉伯数字转中文数字的函数
2007/07/16 PHP
PHP数组的交集array_intersect(),array_intersect_assoc(),array_inter_key()函数的小问题
2011/05/29 PHP
ThinkPHP添加更新标签的方法
2014/12/05 PHP
smarty模板引擎中自定义函数的方法
2015/01/22 PHP
PHP调用.NET的WebService 简单实例
2015/03/27 PHP
php实现在限定区域里自动调整字体大小的类实例
2015/04/02 PHP
laravel 实现设置时区的简单方法
2019/10/10 PHP
发布BlueShow v1.0 图片浏览器(类似lightbox)blueshow.js 打包下载
2007/07/21 Javascript
event.keyCode键码值表 附只能输入特定的字符串代码
2009/05/15 Javascript
W3C Group的JavaScript1.8 新特性介绍
2009/05/19 Javascript
让你的网站可编辑的实现js代码
2009/10/19 Javascript
原生JS实现LOADING效果
2015/03/16 Javascript
javascript使用avalon绑定实现checkbox全选
2015/05/06 Javascript
完善的jquery处理机制
2016/02/21 Javascript
利用Node.JS实现邮件发送功能
2016/10/21 Javascript
Javascript for in的缺陷总结
2017/02/03 Javascript
vue中mint-ui的使用方法
2018/04/04 Javascript
Node.js安装详细步骤教程(Windows版)详解
2019/09/01 Javascript
微信小程序复选框实现多选一功能过程解析
2020/02/14 Javascript
JavaScript实现串行请求的示例代码
2020/09/14 Javascript
python里大整数相乘相关技巧指南
2014/09/12 Python
pandas 按照特定顺序输出的实现代码
2018/07/10 Python
python实现栅栏加解密 支持密钥加密
2019/03/20 Python
Django的models模型的具体使用
2019/07/15 Python
Python打开文件、文件读写操作、with方式、文件常用函数实例分析
2020/01/07 Python
Pycharm小白级简单使用教程
2020/01/08 Python
解决Keras 与 Tensorflow 版本之间的兼容性问题
2020/02/07 Python
Django中使用Json返回数据的实现方法
2020/06/03 Python
python 图像插值 最近邻、双线性、双三次实例
2020/07/05 Python
Python的Tqdm模块实现进度条配置
2021/02/24 Python
手工制作的豪华英式沙发和沙发床:Willow & Hall
2019/05/03 全球购物
日本亚马逊官方网站:Amazon.co.jp
2020/04/14 全球购物
应届生程序员求职信
2013/11/05 职场文书
搬迁通知
2015/04/20 职场文书
如何在C++中调用Python
2021/05/21 Python
上个世纪50年代的可穿戴技术:无线电帽子
2022/02/18 无线电