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的equals(),hashCode()应该在什么时候重写
java·开发语言·jvm
REDcker2 小时前
有限状态机与状态模式详解 FSM建模Java状态模式与C++表驱动模板实践
java·c++·状态模式
你的保护色2 小时前
【无标题】
java·服务器·网络
basketball6162 小时前
C++ 构造函数完全指南:从入门到进阶
java·开发语言·c++
淘矿人3 小时前
Claude辅助DevOps实践
java·大数据·运维·人工智能·算法·bug·devops
小江的记录本3 小时前
【Java基础】泛型:泛型擦除、通配符、上下界限定(附《思维导图》+《面试高频考点清单》)
java·数据结构·后端·mysql·spring·面试·职场和发展
来恩10033 小时前
请求转发与响应重定向的使用
java
@杰克成4 小时前
Java学习30
java·开发语言·学习
次元工程师!4 小时前
LangFlow开发(三)—Bundles组件架构设计(3W+字详细讲解)
java·前端·python·低代码·langflow
oddsand15 小时前
Redis网络模型
java·数据库·redis