某小程序平台桌面版开启 js 调试
2023-4-10 08:55:43 Author: mp.weixin.qq.com(查看原文) 阅读量:31 收藏

网上有很多大同小异的文章介绍如何逆向此类小程序的 js,工作流大体如下:

  1. 安装小而美 app 到 root 过的 Android(或模拟器)

  2. 使用小程序

  3. 在 /data 目录下查找 wxpkg

  4. 使用有人实现好的 nodejs 库解包

  5. 将解包导入 IDE,实现 js 单步调试

这个流程相当于做了重打包,在导入 IDE 之后无法通过开发者的 appid 检查,涉及到网络请求的部分会出错。

能不能直接在原汁原味的生产环境上开启 js 单步调试呢?

在 mac 上的小程序使用 JavaScriptCore 实现。JSC 自带了单步调试,只是默认没有开启。另外由于小程序渲染界面的引擎并不是简单的 WKWebView,本文仅限单步调试 js,不能审查界面元素。

之前公众号发过一个插件,也介绍了原理,但是并没有点破可以直接拿来调小程序:全局开启 iOS / mac 的 WebView 调试

最近 Safari 更新到 16.4,把我的插件搞不兼容了。想起这一茬,顺手水了篇推送。之前的插件实现方式是注入代码到 webinspectord,修改系统检查entitlement 的逻辑。

引用的文章链接中提供的 frida 脚本直接可以用在 mac 上,然后再打开某小而美 mac 版,就可以看到各种可以审查的页面:

居然还用了 JSPatch(注意里面的 _OC_callC)。

在新版的 macOS 上这段脚本不能用了,来看 WebKit 博客怎么说的。

之前 app 的 WKWebView 和 JSContext 能否被调试,取决于应用是否是 Xcode 调试版(具有 get-task-allow),或者使用其他特殊的 entitlement。

现在 Safari 将决定权全权交给开发者,直接在 app 当中设置 WKWebView / JSContext 的 isInspectable 属性为 @YES,就可以细粒度地控制某个页面允许用 F12。

例如 WebKit 官方给的开启 JSContext 调试的示例:

JSContext *jsContext = [JSContext new];jsContext.inspectable = YES;

那么我们只要注入 app(而不是之前的 webinspectord)就可以修改了。

除了 hook 类的初始化方法,frida 里正好有一个 ObjC.chooseSync 函数,可以根据 class 在内存中搜索已经初始化好的对象。

因此我们只需要启动好对应的小程序,然后 frida 附加到 Mini Program 上执行一行 js 即可:

['WKWebView', 'JSContext'].forEach(    clazz => ObjC.chooseSync(ObjC.classes[clazz]).forEach(        v => v.setInspectable_(ptr(1))    ))

小而美的小程序和主程序不在一个进程当中运行,通常会看到两个 Mini Program 进程。

用 python 自动筛选一下:

import frida
mac = frida.get_local_device()if mac.query_system_parameters()['os']['id'] != 'macos': raise RuntimeError('This script is only for Mac OS')
for proc in mac.enumerate_processes(): if proc.name not in ['WeChat', 'Mini Program']: continue
print('Patching %s (%d)' % (proc.name, proc.pid)) session = mac.attach(proc.pid) script = session.create_script(''' ['WKWebView', 'JSContext'].forEach( clazz => ObjC.chooseSync(ObjC.classes[clazz]).forEach( v => v.setInspectable_(ptr(1)) ) ) ''') script.load() script.unload() session.detach()

这个脚本需要关闭 macOS 的 SIP(rootless),将显著降低系统安全性。在 Apple Silicon 上除了关掉 sip,还需要开启 am64e abi,然后重启。

sudo nvram boot-args="-arm64e_preview_abi"

来看效果。

直接调试某社交网站的小程序:

单步进入请求参数,都抓下来了

本文仅限技术讨论。如遇到账号被风控甚至产生其他后果,请自行承担


文章来源: https://mp.weixin.qq.com/s?__biz=Mzk0NDE3MTkzNQ==&mid=2247484688&idx=1&sn=2d38e292b3a9bcf70e679bfb8a4748ce&chksm=c329fbe0f45e72f6f2a935ccedcae1a42e03c1943d59ad0dbc2d1b6ed65704e50454204ee6ed&scene=58&subscene=0#rd
如有侵权请联系:admin#unsafe.sh