免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3594 | 回复: 4
打印 上一主题 下一主题

防止php注入问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-10-03 17:00 |只看该作者 |倒序浏览
5可用积分
请教大家防止php注入,现在使用一个PHP文件里的函数自动过滤所有的提交数据,比如下面
if(isset($_POST)){
//执行过滤语句
}
还要再每个表单提交的PHP文件地方过滤吗?(想省点事),具体使用哪种方法好点,安全跟性能方面。
除了$_POST跟$_GET之外,$_COOKIES也需要过滤吗?

最佳答案

查看完整内容

进数据库前检测一次。如果是mysql的话,用 mysql_real_escape过滤每个参数。显示前检查一次。这个各家有各家的法门。纯文本的话, html_xxxx 什么来着函数可以用。自己查手册去。

论坛徽章:
0
2 [报告]
发表于 2011-10-03 17:00 |只看该作者
进数据库前检测一次。如果是mysql的话,用 mysql_real_escape过滤每个参数。

显示前检查一次。
这个各家有各家的法门。纯文本的话, html_xxxx  什么来着函数可以用。自己查手册去。

论坛徽章:
0
3 [报告]
发表于 2011-10-03 17:03 |只看该作者
是的!!!!!!!!!!!!!

论坛徽章:
0
4 [报告]
发表于 2011-10-03 20:33 |只看该作者
可以用$_REQUIST,全包括了,手册上讲:

$_REQUEST

$_REQUEST — HTTP Request 变量


说明

默认情况下包含了 $_GET,$_POST和 $_COOKIE 的数组。

论坛徽章:
0
5 [报告]
发表于 2011-10-04 11:06 |只看该作者
本帖最后由 itlu 于 2011-10-04 11:35 编辑

谢谢各位朋友,三楼的朋友我把检测代码贴出来
function inject_check($sql)
{              
        return preg_match("/select|insert|update|delete|%27|\*|\/\*|\.\.\/|\.\/|union|into|1=1|load_file|outfile/i", $sql);// 进行过滤
}

if(inject_check($_SERVER["REQUEST_URI"]))
        {
                die('Invalid URL !');
        }

function magic()
{
        if(!get_magic_quotes_gpc()&&isset($_POST))
        {
                foreach($_POST as $key=>$v)
                {
                        if(!is_array($v))
                                $_POST[$key]=addslashes($v);
                }
                        }

magic();

四楼的朋友,如果用mysql_real_escape_string检测参数是不是要把关闭魔术引号,如果开启magic_quotes_gpc,再用mysql_real_escape_string转义不安全字符会不会转义二次。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP