BUUCTF : [RoarCTF 2019]Easy Java

BUUCTF : [RoarCTF 2019]Easy Java

本文知识点:

WEB-INF目录:WEB-INF 是Java的WEB应用的安全目录。如果想在页面中直接访问其中的文件,必须通过web.xml文件对要访问的文件进行相应映射才能访问。

  • /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:数据库配置文件

题目界面

查看源码

  • 查看源码发现这个链接
  • 访问的时候发现返回文件未找到

  • 尝试看是否是sql注入,发现不是

  • 没招了,看题解

看题解

题解中主要是讲解了WEB-INF目录下的作用(可看文章开头),只有记住了!

  1. 查看配置文件

下面配置的含义:

  1. 声明一个名为 FlagController 的 Servlet
  2. 对应的Java类是 com.wm.ctf.FlagController
xml 复制代码
<servlet>
    <servlet-name>FlagController</servlet-name>
    <servlet-class>com.wm.ctf.FlagController</servlet-class>
</servlet>

下面配置的含义:

  1. 引用上面声明的FlagController
  2. 当访问/Flag这个链接的时候,转发给Java类com.wm.ctf.FlagController
xml 复制代码
<servlet-mapping>
    <servlet-name>FlagController</servlet-name>
    <url-pattern>/Flag</url-pattern>
</servlet-mapping>

servlet中配置的java类的类名是全限定名:com.wm.ctf.FlagController

什么是全限定名:可以简单理解为他是某一个路径下,通过点.进行分隔的路径加类名。

什么意思呢? 比如com.wm.ctf.FlagController, 假设我们的某一路径在/project(某一路径)。 那这个全限定名就表示在/project/com/wm/ctf/(路径通过点.分隔)的路径下有一个名为FlagController.class的类。

  1. 尝试得到源码
  • 在这道题目中我首先尝试将filename设置为 /WEB-INF/src/com/wm/ctf/FlagController.java,但是没得到什么结果,希望懂的大佬能讲解下

  • 尝试访问他的class(字节码:可看本文后面的解释)文件,然后反编译得到源代码,如下:

  • 拷贝url
  • 浏览器中打开

这里可以简单了解下java文件的后缀:

Java 文件的两种主要格式:

文件类型 扩展名 内容 用途 可读性
源代码文件 .java 人类可读的 Java 代码 开发者编写、编辑 直接阅读
字节码文件 .class JVM 可执行的字节码 运行程序 需要反编译
  1. 反编译源码,得到flag
  • 我随便找了一个在线的反编译软件,得到.class(字节码文件)文件的反编译结果,如下:
  • base64解码得到flag
相关推荐
百锦再2 分钟前
Java中的char、String、StringBuilder与StringBuffer 深度详解
java·开发语言·python·struts·kafka·tomcat·maven
努力努力再努力wz1 小时前
【Linux网络系列】:TCP 的秩序与策略:揭秘传输层如何从不可靠的网络中构建绝对可靠的通信信道
java·linux·开发语言·数据结构·c++·python·算法
yy.y--2 小时前
Java数组逆序读写文件实战
java·开发语言
BD_Marathon3 小时前
IDEA创建多级包时显示在同一行怎么办
java·ide·intellij-idea
亓才孓3 小时前
【Exception】CONDITIONS EVALUATION REPORT条件评估报告
java·开发语言·mybatis
硅基动力AI3 小时前
如何判断一个关键词值不值得做?
java·前端·数据库
重生之后端学习4 小时前
78. 子集
java·数据结构·算法·职场和发展·深度优先
那起舞的日子4 小时前
斐波那契数列
java·算法
想用offer打牌5 小时前
一站式了解接口防刷(限流)的基本操作
java·后端·架构
姜源Jerry6 小时前
【Trae】Trae IDE&SOLO浅尝
java·ide·ai