栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

山东大学软件学院项目实训-创新实训-山大软院网络攻防靶场实验平台(十四)-任意文件下载漏洞(2)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

山东大学软件学院项目实训-创新实训-山大软院网络攻防靶场实验平台(十四)-任意文件下载漏洞(2)

目录
  • 前言:
  • 3、编写“任意文件下载漏洞”后台
  • 4、编写“任意文件下载漏洞”前台
  • 5、运行测试


前言:

前面的博客记录学习任意文件下载漏洞相关知识,并思考如何构造任意文件下载漏洞环境。本篇博客记录下任意文件下载漏洞的实现过程与关键代码。


3、编写“任意文件下载漏洞”后台

构建任意文件下载漏洞的基本思路是,在项目根目录中,新建一个 flag 文件夹,用于存放用户请求下载的内容,然后在该文件夹的上级目录中,新建文件 flag.txt ,测试者需要点击下载后,使用 burpsuite 抓包,并且修改下载的文件为上层目录文件,得到 flag。

根据上面提供的思路,主要实现代码如下:

indexController.java:接收请求"/“,”/index",“/index.html”,匹配到 FileDownload.html

package com.example.filedownload.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class indexController {
    @RequestMapping(value = {"/","/index.html","/index.html"})
    public String FileDownload(){
        return "FileDownload";
    }
}

FileDownloadController.java

package com.example.filedownload.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;

@Controller
public class FileDownloadController {
    @RequestMapping("/Download")
    public void MVCDownload(@RequestParam("filename") String filename,
                            HttpServletRequest request, HttpServletResponse response) throws IOException {
        byte[] bytes = new byte[10];
        int len = -1;
        try {
            InputStream inputStream = new FileInputStream("D:\Code\SDUWeb\FileDownload\flag\" + filename);

            response.setCharacterEncoding("utf-8");
            response.setContentType("text/html;charset=UTF-8");
            response.addHeader("content-Type", "application/octet-stream");//二进制文件
            response.addHeader("content-Disposition", "attachment;filename=" + filename);

            while ((len = inputStream.read(bytes)) > 0) {
                response.getOutputStream().write(bytes, 0, len);
            }
            response.getOutputStream().close();
            inputStream.close();

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

4、编写“任意文件下载漏洞”前台

FileDownload.html




    
    文件下载



点击下载flag.txt?




5、运行测试

浏览器:Firefox

抓包工具:burpsuite

首先启动 burpsuite

配置监听代理

Firefox 配置代理

启动项目

Firefox 浏览器访问

点击下载后,burpsuite 拦截到该请求的数据包

把请求下载的文件修改为上级目录中的 flag 文件

forWord,发现已经下载好 flag 文件

打开该文件

得到 flag,测试成功。


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/854978.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号