开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 3701|回复: 21
收起左侧

[技术专题] VX小程序逆向分析

[复制链接]
发表于 2023-3-24 17:50:39 | 显示全部楼层 |阅读模式   广东省深圳市
本帖最后由 wwger 于 2023-3-24 17:52 编辑

前言
frida虽然确实调试起来相当方便,但是Xposed由于能够安装在用户手机上实现持久化的hook,至今受到很多人的青睐,对于VX小程序wx.request API,本文将以该API作为用例,介绍如何使用Xposed来对VX小程序js API进行hook首先我们要知道VX小程序跟服务器交互最终都会调用wx.request这个api跟服务器交互,我们的最终目的是要通过分析这个api得到request数据和response数据,测试的VX版本是8.0.30
背景知识
  众所周知,Xposed主要用于安卓Java层的Hook,而VX小程序则是由JS编写的,显然无法直接进行hook。安卓有一个WebView的组件能够用于网页的解析和js的执行,并且提供了JSBridge可以支持js代码调用安卓的java代码,VX小程序正是以此为基础开发了它的VX小程序框架,VX小程序特有的API则是由这个框架中的WxJsApiBridge提供的,因此以wx.开头的API都能在这个框架中找到对应的Java代码,所以我们虽然不能直接hook js代码,但是我们可以通过hook这些js api对应的Java代码来实现VX小程序api的hook。
Frida调试
  在编写Xposed插件前,首先先使用Frida进行逆向分析以及hook调试,确保功能能够实现后在用Xposed编写插件,毕竟Xposed插件调试起来还是不如Frida方便。
  首先我们要知道,js代码中的wx.xxx字符串一定会在java层中出现吗?答案是否定的,wx.getLocation和其他一些api的名字确实会在java层出现,java层的字段表现形式就是 String NAME = getLocation但是我们今天要分析的api wx.requestjava层中不叫这个名字,因此在jadx反编译完VX以后,直接搜索该字符串是搜索不到的既然搜索不到那就换一个思路,VX小程序wx.xxx最终都会通过WxJsApiBridge调用到java层对应的api实现,所以我们可以通过frida hook这个类相应的方法来确定wx.requestjava层对应的api叫什么名字,通过jadx搜索发现有一个类叫做com.tencent.mm.appbrand.commonjni.AppBrandJsBridgeBinding
  定位到具体的类以后,我们可以用Objectionhook整个类来观察这个类中函数的调用情况,以此发现主要的函数。不过在hook之前,需要注意的是,VX小程序一般会以新进程的方式启动,其进程名为com.tencent.mm:appbrand0、com.tencent.mm:appbrand1com.tencent.mm:appbrand2com.tencent.mm:appbrand3com.tencent.mm:appbrand4VX最多同时运行5个小程序进程,所以最多只能同时运行5个小程序,如果打开第6个小程序,VX会把最近不怎么用的小程序关掉给新打开的小程序运行,因此,如果直接用frida -U com.tencent.mm -l xxx或者objection -g com.tencent.mm explorehook的话,是无法看到函数调用的,因为你hook的进程不是VX小程序的进程而是VX的进程。所以我们要指定pid来进行hook,可以使用dumpsys activity top | grep ACTIVITY来得到;也可以使用frida -UF -l xxxhook当前最顶层的Activity。对于Xposed则没有这个问题,只需指定VX的包名就会自动hook上所有的子进程。

由于分享有字数限制,具体看文档

wx.request逆向笔记.rar

496.11 KB, 下载次数: 107, 下载积分: 精币 -2 枚

评分

参与人数 3好评 +3 精币 +6 收起 理由
流年浮生 + 1 + 1 wx.getStorage 大佬能研究一下,小程序读取本地存储吗,
wiyxwd + 1 + 2 支持开源~!感谢分享
xslyhk + 1 + 3 支持开源~!感谢分享

查看全部评分


签到天数: 6 天

发表于 2024-4-28 21:40:07 | 显示全部楼层   广东省惠州市
坚持学习,支持论坛
回复 支持 反对

使用道具 举报

发表于 2023-9-19 11:00:58 | 显示全部楼层   广西壮族自治区防城港市
1111111111111111111111111111111111
回复 支持 反对

使用道具 举报

结帖率:100% (2/2)

签到天数: 9 天

发表于 2023-6-22 23:22:23 | 显示全部楼层   福建省厦门市

支持开源~!感谢分享
回复 支持 反对

使用道具 举报

签到天数: 3 天

发表于 2023-6-12 01:26:12 | 显示全部楼层   浙江省温州市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

发表于 2023-6-7 03:28:14 | 显示全部楼层   四川省宜宾市
谢谢分享
回复 支持 反对

使用道具 举报

发表于 2023-5-12 10:07:53 | 显示全部楼层   黑龙江省牡丹江市
感谢分享.学习中.
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)
发表于 2023-4-25 11:47:37 | 显示全部楼层   河南省郑州市
谢谢分享
回复 支持 反对

使用道具 举报

结帖率:92% (33/36)
发表于 2023-4-21 21:20:31 | 显示全部楼层   日本
刚好在学小程序,谢谢大佬
回复 支持 反对

使用道具 举报

发表于 2023-4-9 21:22:51 | 显示全部楼层   广东省深圳市
加油!努力学习!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

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