吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 5469|回复: 5
收起左侧

[Web逆向] 【使用AST还原JS混淆代码应用】 猿人学爬虫攻防赛 第九题详解

  [复制链接]
天空宫阙 发表于 2020-12-29 22:13
本帖最后由 天空宫阙 于 2020-12-29 22:07 编辑

猿人学第九题

题目地址  

http://match.yuanrenxue.com/match/9

需要的工具或代码准备

ob-decrypt

利用AST(抽象语法树)对JavaScript代码进行部分还原提高代码可读性的开源仓库

https://github.com/DingZaiHub/ob-decrypt

我fork之后改了一个小bug已经提了pull request暂未被merge,针对本题建议使用以下代码。

https://github.com/skygongque/ob-decrypt

猿人学网站提供的ob解混淆工具  

http://tool.yuanrenxue.com/decode_obfuscator

网站提供的ob解混淆工具的通用性很高且还原程度很高,但针对本题改变了部分逻辑而且不易发现。  

reres

ReRes可以用来更改页面请求响应的内容。通过指定规则,您可以把请求映射到其他的url,也可以映射到本机的文件或者目录。ReRes支持单个url映射,也支持目录映射。
谷歌应用商店下载  

https://chrome.google.com/webstore/detail/reres/gieocpkbblidnocefjakldecahgeeica?hl=en

github 地址  

https://github.com/annnhan/ReRes

浏览器调试

刚按F12进行调试就被给了一个下马威,是一个udc.js的文件是一个无限debugger拉到最后发现是一个1万多行的文件。

1.png

把udc.js文件保存下来,使用ob-decrypt工具进行还原,还原后的udc.js文件通过reres映射回去。  

此时可以重新请求测试一下,发现仍然可以拿到数据。   

使用charles或者fiddler抓一下完整的包发现第一次请求http://match.yuanrenxue.com/match/9是一段代码还原后/match/9还原后
其中有一段代码明显是设置cookie的  

3.png

但是发现设置cookie时调用的函数decrypt并没有在这个js文件中定义,但是这个文件引用了我们之前还原过的文件udc.js。
在9_udc_decrypt.js这个文件搜索果然找到了decrypt的定义。

6.png

然后我们可以设一个断点在decrypt的定义调用之后
然后在控制台输入下面代码。  

for (var _0xe88f11 = 1; _0xe88f11 <= 2; _0xe88f11++) {
    res = decrypt("1609241711") + "r";
  }
  document["cookie"] = "m=" + (_0xe88f11 - 1)["toString"]() + res + "; path=/";

4.png

发现可以正常的设置cookie。
此时后面可以注释掉window["decrypt"] = _0x4f6d79;后面的代码重复上面的操作发现仍然可以正常设置cookie说明之后的代码都是无用的代码在扣js的时候应该去掉。
这个时候我们总体的逻辑就清楚了,在udc.js中定义decrypt在第一次访问主页的时候后调用上面这段代码设置cookie然后带这个设置好的cookie在访问接口就可以拿到数据了。  

node.js中调试

还原后的udc.js文件将window["decrypt"] = _0x4f6d79后面的代码去掉剩下的在nodejs中调试。
调试的时候注意try...catch的代码以及对window和global操作的代码。因为我们已经可以在浏览器动态调试,所以可以跟浏览器中对于位置的执行结果进行比较。
最后总结出来的几个在node.js运行需要改动的地方。   

  1. 发现浏览器这个if判断是有值的,所以应该什么都不执行。

9.png

  1. 补充navigator 和 并把window指向global  

10.png

  1. 最终node环境和浏览器环境的结果相同。  

11.png

其他细节第一次请求http://match.yuanrenxue.com/match/9设置cookie中的时间戳是动态的并且加密的次数也不同,时间戳可以用正则表达取一下,加密多少次没有跟sessionid绑定而是以加密结果的第一位传给服务器,所以可以固定加密次数。  

完整代码

完整代码  

成功留念

success09.png

免费评分

参与人数 4威望 +1 吾爱币 +18 热心值 +4 收起 理由
muyanlucky + 1 + 1 谢谢@Thanks!
ufo0033 + 1 + 1 控制流平坦化的代码, 用 “|” 切割 出数组,但是 原js 没有这个拼接字符.
苏紫方璇 + 1 + 15 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
漁滒 + 1 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

影子记忆 发表于 2020-12-29 22:48
学习了!
cybermay 发表于 2020-12-30 00:32
寒冰流火 发表于 2020-12-30 09:38
不苦小和尚 发表于 2021-1-24 19:08
用哪个还原无所谓,楼主忘了说,把网页里的也解密一下才行
为了正义000 发表于 2021-9-9 14:37
强!,一会看看
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-24 22:05

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表