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
相关推荐
4 小时前
java关于内部类
java·开发语言
好好沉淀4 小时前
Java 项目中的 .idea 与 target 文件夹
java·开发语言·intellij-idea
gusijin4 小时前
解决idea启动报错java: OutOfMemoryError: insufficient memory
java·ide·intellij-idea
To Be Clean Coder4 小时前
【Spring源码】createBean如何寻找构造器(二)——单参数构造器的场景
java·后端·spring
吨~吨~吨~4 小时前
解决 IntelliJ IDEA 运行时“命令行过长”问题:使用 JAR
java·ide·intellij-idea
你才是臭弟弟4 小时前
SpringBoot 集成MinIo(根据上传文件.后缀自动归类)
java·spring boot·后端
短剑重铸之日4 小时前
《设计模式》第二篇:单例模式
java·单例模式·设计模式·懒汉式·恶汉式
码农水水5 小时前
得物Java面试被问:消息队列的死信队列和重试机制
java·开发语言·jvm·数据结构·机器学习·面试·职场和发展
summer_du5 小时前
IDEA插件下载缓慢,如何解决?
java·ide·intellij-idea
东东5165 小时前
高校智能排课系统 (ssm+vue)
java·开发语言