首页 > php教程 > php手册 > 正文

linux防止php伪造本地文件解决方法

WBOY
发布: 2016-05-25 16:41:00
原创
1204 人浏览过

我们举例只讲linux的系统,但是防止方法在任何系统都是有效的,下面我们先来看看等操作,你可以这样使用,代码如下:

http://www.phprm.com/index.php?page=../etc/passwd 

http://www.phprm.com/index.php?page=../../../etc/passwd 

http://www.phprm.com/index.php?page=..../../etc/passwd

获取更多数据:

etc/profile  
etc/services  
/etc/passwd  
/etc/shadow  
/etc/group  
/etc/security/group  
/etc/security/passwd  
/etc/security/user  
/etc/security/environ  
/etc/security/limits  
/usr/lib/security/mkuser.default
登录后复制

像上面代码,如果你是

?page=$_GET的话这样就完了,分析原因,因为我们分页只有数字,那么我们这样操作,代码如下:

?page=intval($_GET);

这样就无法把字符提交了,我们利用了intval函数进行了过滤,那么对于提交字符怎么处理呢,在处理字符时我们利用php自带函数的函数 addslashes和htmlspecialchars进行过滤,代码如下:

$body = htmlspecialchars(isset($_GET[$str])?$_GET[$str]:'');
登录后复制

这样就基本过滤了各种安全注入,当然如果你服务器有漏洞在php上是解决不了的.

教程链接:

随意转载~但请保留教程地址★

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!