对于无扩展名的PHP程序的研究
作者:PHP
环境:WinXp Pro + Apache 2.0.49 + PHP 4.3.5 (Module)
将没有扩展名的PHP代码,给PHP解释器解释,好处在于大大增加了安全性,给入侵的人、盗链的人,增加了迷惑性。例如:
http://www.msger.net/chat?username=Hackfan
http://www.msger.net/images/test.gif
从一般认识来看,上文的2个URL很有可能是这样的:
/
|-chat/
????? |-index.php
|-images/
????? |-test.gif
但是Apache + PHP可以让chat、images变成一个PHP程序,而把后面的部分作为参数。事实上,这2个URL很有可能:
/
|-chat.??? (PHP File)
|-images.? (PHP File)
|-imagessecret/? (Directory)
而http://www.msger.net/images/test.gif将交给images这个PHP程序来处理。下面给出这个程序的部分环境变量:
_SERVER["REQUEST_URI"] = /images/test.gif
_SERVER["SCRIPT_NAME"] = /images
_SERVER["PATH_INFO"]?? = /test.gif
_SERVER["PHP_SELF"]??? = /images/test.gif
大家注意到了,Apache除了对_SERVER["SCRIPT_NAME"]有正确的判断以外,其他的信息几乎都是被我们欺骗了。不知道大家想到利用这个性质我们可以做什么,反正我想到了可以防止图片被盗链。
另外,找遍了很多资料,最后还是通过自己,使得Apache能够对没有扩展名的PHP文件进行正确的解释:
修改httpd.conf,找到 ,增加:DefaultType application/x-httpd-php
最后一些遗留问题:
对于http://www.msger.net/images/../test.gif这类的请求,服务器会如何处理呢?不要用IE发送这样的请求,因为IE自动会处理。

本文围绕无扩展名的PHP程序展开研究,在WinXp Pro + Apache 2.0.49 + PHP 4.3.5环境下,将无扩展名PHP代码交予解释器可增加安全性与迷惑性,还能防止图片被盗链。同时介绍了让Apache正确解释此类文件的方法,最后提出遗留问题。
5007

被折叠的 条评论
为什么被折叠?



