记一次对捕获的样本进行分析
之所以开始学习V8漏洞利用,就是起源于需要对一个捕获到的样本进行分析复现,这里记录一下。
解混淆
抓到的样本跟正常情况下的JavaScript代码差不多,都是有一坨,这个时候需要对代码进行美化,js代码美化的工具一堆。
美化后就是需要对代码进行分析了,最开始有一个变量:
1 | const a = ['w79PNDLDqw==', 'w4F7ccK9w54=', 'wq0pw4bCi8OF', 'P8OtSsOnw4dQw6F0A8KlPGLCl8O7w5LCpMOmw60zd8Ku', 'w6lSSMKfw4I=', 'w6rDo8KZwpIe', 'wrjDpjxVw5g=', 'FcKGYQLDuw==', 'wrldw4PDsXk=', 'wo90w6XDi34=', 'wrYAblPCpA==', 'wr3CpFjDjMKh', 'w5cwwqTCocOX', 'wrPCtcKawpHDkQ==', 'w6Auw7PDgAU=', 'RMKIwrcWfg==', 'wrInW8KUMQ==', 'QsOIw6xXGQ==', 'woMYw7pQwo9Iw4g2wrDDjMOq', 'woIhW8KgKcKiU8KIEsKcw6XCuBgmwpxdwp5/YlbCjw==', 'w6U2w4TDpRTDoBA=', 'QAvDqDBLBsOjCHpgc1E6wrk8JX3DjUfDkVpcwoPDow==', 'wqPCkcK+wqQ=', 'wpMrQcKmL8K+BsOERMOTwrw=', 'JsO2wpjDlQzClVs=', 'w6LDm8OLwoE=', 'Aj/DpRZc', 'w73DkV5LTw==', 'wqfChsKiwqTDj18rXCg=', 'wozCiHJO', 'fULDnwI=', 'w4pFw5DCl8OI', 'w7o7wqzCjcOU', 'JcOwU8O4w5A=', 'wpfDnwJkw4g=', 'woIbf1DCmQ==', 'CxDDthhh', 'w4DCuzMmDw==', 'WCFFRDc=', 'E8K+Yh7DpQ==', 'w755ZsK9dw==', 'w4RVBsK9aQ==', 'w6kRwofCvcOO', 'LhPCg15ba8O4EGp7GD8qw5QnPA==', 'woUyw7LCmMON', 'wrPCgcK8wr/DrA==', 'w4bDpUxydsO3', 'EsKzSQHDgiM=', 'wr7CuH/DrMKG', 'w73DicKCwpEs', 'w6o8w4fDsgnDpA==', 'wobChHBFwpdA', 'w5vCuDEhFg==', 'SMKybsKQwqw=', 'agFzZik=', 'FxkTcy8=', 'w4XDvsKO', 'w6Jlw47DvsOWw5dXag==', 'w6TDvsKNwowxwoA=', 'wqxEMF/Cl8Kk', 'w7bCkwoIMcOQ', 'woVFPyHCk1PDqj8=', 'w4J7wpDChw==', 'AMKzTMOr', 'NcOswobDjQ==', 'w59lO8KjajrDk8Odwp4=', 'wpMyfETCncO1GF97', 'w7wRwrvCm8Ou', 'woYKw5LCsw==', 'w4Vuw4XDvg==', 'wpzCgHJXwoY=', 'wqdmw4dWOA==', 'wr7DojlEw7Y=', 'wr7Dpzdew7Yq', 'VsKNwqUJc8Kd', 'w5d2wpPCgE/CncK5wonCkBDCpsKNw70=']; |
随后定义了一个b函数:
1 | const b = function (c, d) { |
然后在之后的代码中有一堆:b('0x0', 'gW&A')
这样的代码,很明显,代码是被混淆的,解混淆函数就是b函数,所以随后需要对b函数进行分析,然后得到解混淆的脚本:
1 | import base64 |
混淆部分并不是很难,但是在研究b函数的过程中发现一个神奇的函数
反美化
1 | h['prototype']['uWXLxq'] = function (j) { |
这是一个死循环函数,而程序总会运行到这,所以调试运行美化后的样本,总会进行入死循环,导致无法执行后续流程。
深入研究发现:
1 | const h = function (i) { |
关键代码在上述这部分,Xwletx
函数对lbERAb
函数进行了正则匹配,但是按照上面的代码匹配总是失败,所以之后调用了:this['tKNvcJ'](0) -> !Boolean(~0) == false -> this['uWXLxq'](this['EkZxlG']) <- 死循环函数
随后发现,原始代码中,lbERAb
函数为:this['lbERAb']=function(){return 'newState';};
,如果我这么定义代码,正则匹配就能匹配成功,随后的流程就是:this['tKNvcJ'](1) -> !Boolean(~1) == true-> return 1
,就不会进行死循环函数了。
从上诉逻辑可以看出,该函数就是专门用来针对代码美化的,不过单了解了其作用后,直接把这块的逻辑删除就好了。
而且这种反美化的代码还不止一处,不过这种的特点是正则匹配,遇到这种,大概率都是可以删掉的。
记一次对捕获的样本进行分析