热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

图形化漏洞利用DemoJavaFX版

一个帮助安全人员快速构建一个图形化的、跨平

山高水长,天涯未远,江湖再见


✔ 0x01 这是个嘛?


这是一个构建图形化漏洞利用的一个项目,已经写好架子,只需要往里填充exp即可,帮助安全人员快速构建一个图形化的、跨平台的漏洞利用工具。

虽然有很多优秀的命令行利用工具,但我觉得还是带界面的方便。

使用本项目,你不需要懂太多Java语言,只需要了解基本的语法,参考自带的EXP例子,即可快速开发一款属于你自己的漏洞利用工具。


✔ 0x02 Demo


项目地址:https://github.com/yhy0/ExpDemo-JavaFX

废话不多说,先上效果图,自带CVE-2020-14882 Weblogic远程代码执行漏洞


✔ 0x03 编写属于你的图像化漏洞利用工具


3.1 项目结构

    .
    ├── ExpDemo-JavaFX.iml
    ├── pom.xml maven工程的基本文件
    └── src
    └── main
    ├── deploy
    │ └── ExpDemo-JavaFX-1.0.icns
    ├── java
    │ └── com
    │ └── yhy
    │ ├── Controller.java 控制JavaFX图形化界面的各种显示、事件等,核心代码
            │           ├── Main.java       JavaFX 应用程序的入口
            │           ├── core           核心代码文件夹
    │ │ ├── CVE_2020_14882.java exp编写示例
            │           │   ├── Constants.java   一些常量信息
            │           │   ├── ExploitInterface.java  exp 编写要实现的接口
            │           │   ├── Job.java      批量检查的线程池
            │           │   └── VulInfo.java   映射批量检查界面中的表格,信息基本类
            │           └── tools            工具文件夹
            │               ├── HttpTool.java   HTTP 请求封装
            │               ├── MyCERT.java     HTTPS 请求证书设置
            │               └── Tools.java      一些处理函数
            └── resources         资源文件夹
                ├── sample.fxml   JavaFX图形化界面描述文件
    ├── sec.png
    └── weixin.jpg

    3.2 编写EXP

    编写EXP时,要使用 implements
    实现ExploitInterface
    接口,实现接口中的几个方法

    • checkVUL       使用poc检查是否漏洞

    • exeCMD          使用exp执行命令

    • uploadFile       使用命令执行 写webshell,上传文件

    • getWebPath    获取网站的web目录,供上传文件使用

    • isVul      是否存在漏洞,检查时会根据结构自动赋值,供后续调用

    EXP具体编写请参考 src/main/java/com/yhy/core/CVE_2020_14882.java
    示例

    当编写完EXP后,转到 src/main/java/com/yhy/core/Constants.java
    文件,修改CVES
    变量,即图像化界面中可供选择的漏洞列表

    编写完后,可以直接执行Main
    类, 查看是否正常运行。

    3.3 部署,发布

    当一切编写完成,bug修复完毕,在项目根目录下执行 mvn jfx:jar
    即可生成 jar文件。

    对方没有Java环境,不想安装Java怎么办?

    使用mvn jfx:native
    命令生产对应平台的文件,比如Mac 下,执行命令mvn jfx:native
    命令就会在 target/jfx/native 目录下生成打包后应用,带可执行文件,带 JRE 运行环境,很大,180M左右。

    mvn clean
    用于清除生成的文件。


    ✔ 0x04 界面修改


    对界面不满意,或者想添加其他功能

    安装 JavaFx Scene Builder

    https://www.oracle.com/java/technologies/javafxscenebuilder-1x-archive-downloads.html

    安装完,在IDEA中右键打开(设置好JavaFx Scene Builder的路径)

    打开后

    想添加什么控件,直接从Scene Builder的左边控件栏中拖拽一个到界面设计区域,然后只需要关心右侧栏第三个Code
    fx:id
    On Action

    比如想添加一个 输入框,搜索框查询,然后拖一个 TextField
    控件到设计区

    为这个 TextField
    设置一个fx:id
    ,然后Ctrl+s
    保存,  sample.fxml
    会做出相应的更改,不需要关心

    之后到src/main/java/com/yhy/Controller.java
    文件编写逻辑

    1. 使用@FXML
      注解,声明变量

    2. 在函数中使用变量

      使用this.cmd.getText()
      获取输入的值

             使用this.cmd.setText()
    设置值


            其他控件使用,请参考src/main/java/com/yhy/Controller.java
    ,或者自行学习JavaFX。



    推荐阅读
    • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
      本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
    • Java序列化对象传给PHP的方法及原理解析
      本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
    • 本文介绍了使用kotlin实现动画效果的方法,包括上下移动、放大缩小、旋转等功能。通过代码示例演示了如何使用ObjectAnimator和AnimatorSet来实现动画效果,并提供了实现抖动效果的代码。同时还介绍了如何使用translationY和translationX来实现上下和左右移动的效果。最后还提供了一个anim_small.xml文件的代码示例,可以用来实现放大缩小的效果。 ... [详细]
    • android listview OnItemClickListener失效原因
      最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
    • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
    • eclipse学习(第三章:ssh中的Hibernate)——11.Hibernate的缓存(2级缓存,get和load)
      本文介绍了eclipse学习中的第三章内容,主要讲解了ssh中的Hibernate的缓存,包括2级缓存和get方法、load方法的区别。文章还涉及了项目实践和相关知识点的讲解。 ... [详细]
    • XML介绍与使用的概述及标签规则
      本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
    • flowable工作流 流程变量_信也科技工作流平台的技术实践
      1背景随着公司业务发展及内部业务流程诉求的增长,目前信息化系统不能够很好满足期望,主要体现如下:目前OA流程引擎无法满足企业特定业务流程需求,且移动端体 ... [详细]
    • Java在运行已编译完成的类时,是通过java虚拟机来装载和执行的,java虚拟机通过操作系统命令JAVA_HOMEbinjava–option来启 ... [详细]
    • 在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板
      本文介绍了在Xamarin XAML语言中如何在页面级别构建ControlTemplate控件模板的方法和步骤,包括将ResourceDictionary添加到页面中以及在ResourceDictionary中实现模板的构建。通过本文的阅读,读者可以了解到在Xamarin XAML语言中构建控件模板的具体操作步骤和语法形式。 ... [详细]
    • 如何用JNI技术调用Java接口以及提高Java性能的详解
      本文介绍了如何使用JNI技术调用Java接口,并详细解析了如何通过JNI技术提高Java的性能。同时还讨论了JNI调用Java的private方法、Java开发中使用JNI技术的情况以及使用Java的JNI技术调用C++时的运行效率问题。文章还介绍了JNIEnv类型的使用方法,包括创建Java对象、调用Java对象的方法、获取Java对象的属性等操作。 ... [详细]
    • 如何实现JDK版本的切换功能,解决开发环境冲突问题
      本文介绍了在开发过程中遇到JDK版本冲突的情况,以及如何通过修改环境变量实现JDK版本的切换功能,解决开发环境冲突的问题。通过合理的切换环境,可以更好地进行项目开发。同时,提醒读者注意不仅限于1.7和1.8版本的转换,还要适应不同项目和个人开发习惯的需求。 ... [详细]
    • 恶意软件分析的最佳编程语言及其应用
      本文介绍了学习恶意软件分析和逆向工程领域时最适合的编程语言,并重点讨论了Python的优点。Python是一种解释型、多用途的语言,具有可读性高、可快速开发、易于学习的特点。作者分享了在本地恶意软件分析中使用Python的经验,包括快速复制恶意软件组件以更好地理解其工作。此外,作者还提到了Python的跨平台优势,使得在不同操作系统上运行代码变得更加方便。 ... [详细]
    • DSP中cmd文件的命令文件组成及其作用
      本文介绍了DSP中cmd文件的命令文件的组成和作用,包括链接器配置文件的存放链接器配置信息、命令文件的组成、MEMORY和SECTIONS两个伪指令的使用、CMD分配ROM和RAM空间的目的以及MEMORY指定芯片的ROM和RAM大小和划分区间的方法。同时强调了根据不同芯片进行修改的必要性,以适应不同芯片的存储用户程序的需求。 ... [详细]
    • 开发笔记:spring boot项目打成war包部署到服务器的步骤与注意事项
      本文介绍了将spring boot项目打成war包并部署到服务器的步骤与注意事项。通过本文的学习,读者可以了解到如何将spring boot项目打包成war包,并成功地部署到服务器上。 ... [详细]
    author-avatar
    攸攸慢
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有