当前位置:首页 > 网站建设 > 正文内容

vscode运行vue项目mac(vscode运行vue项目不小心直接关闭vscode)

网站建设1年前 (2023-08-15)501

今天开始介绍如何一步步逆向微信app,写一个自动抢红包插件。我们最终成品是写一个能自动抢红包并且在非越狱手机上安装的多开微信。

我暂时打算分3篇文章介绍整个逆向开发过程。逆向的是目前为止微信最新版本6.6.1。我们能做到的是微信APP在前台任何页面有红包消息到来时,实现自动抢红包。

前提 1. 一台越狱iPhone手机,最好是iPhone5s及以上型号手机,因为从iPhone5s后全是arm64处理器。 2. 逆向工具集

检测工具 如:Reveal、tcpdump等

反编译工具(反汇编工具 - 分析二进制文件并得到一些信息) 如:IDA、Hopper Disassembler、classdump等

调试工具 如:lldb、Cycript等

开发工具 如:Xcode、theos等

打包工具

如:iTools、iOS App Signer等

辅助工具

如:OPENSSH、vim、ps、network-cmds等

检测工具 如:Reveal、tcpdump等

反编译工具(反汇编工具 - 分析二进制文件并得到一些信息) 如:IDA、Hopper Disassembler、classdump等

调试工具 如:lldb、Cycript等

开发工具 如:Xcode、theos等

打包工具

如:iTools、iOS App Signer等

辅助工具

如:OPENSSH、vim、ps、network-cmds等

关于逆向开发和工具集的介绍、使用我在原来的文章中已经介绍过,我们在这里不再介绍直接使用。有疑惑或者兴趣的童鞋可以关注我微信公众号:乐Coding查看。

砸壳导出头文件

砸壳把微信的Mach-O文件拷贝到电脑,然后用classdump导出头文件留作备用。这两步我在逆向第一课中已经介绍过不在赘述。如果觉得自己砸壳还得拷贝到电脑麻烦,可以从PP助手上下载相同版本的越狱包。

展开全文

查找收红包方法

我们要实现在任何页面都能自动抢红包,首先我们要找到收红包的接口,然后再实现拆红包和抢红包。

如何找到收红包的接口呢,我们要从聊天页面开始。看看当红包消息到来时,哪些方法会被调用。

一、定位聊天控制器

在越狱手机上打开微信,点击进入单聊或者群聊页面。

1. 打开Mac终端,ssh连接到手机

这里的192.168.220.195是我越狱手机的IP地址,你操作时要换成自己手机的IP地址

ssh root@192.168.220.1952. 查看微信进程ID ps -e| grepWeChat

3. 使用cycript附加进程 cycript -p WeChat 4. 找到当前的控制器

找到当前的聊天控制器名字可以使用Reveal一眼看到,也可以使用下面我介绍的第二种方法。

4.1打印UIView对象

UIApp.keyWindow.recursiveDeion().toString()

打印结果如下:

4.2选择任意一个控件,用控件地址调用nextResponder方法,找到控制器。

如果一步不是,就递归调用,直到nextResponder是ViewController为止。

我们以上图中的蓝色标注ImageView为例查找。

所以聊天的控制器就是BaseMsgContentViewController。查看我们导出的头文件也能找到同名的BaseMsgContentViewController.h文件。

二、 创建Tweak项目

我们已经找到了聊天页面的控制器名,并且发现有同名的头文件。下面我们先来创建一个Tweak项目用于以后的调试。

在Mac上创建微信的Tweak项目,不清楚的请移步逆向第二课。

创建命令和最终项目目录如下图:

创建成功后,Makefile初始内容:

include $(THEOS)/makefiles/common.mkTWEAK_NAME =WXRedTweakWXRedTweak_FILES =Tweak.xminclude $(THEOS_MAKE_PATH)/tweak.mkafter-install::install.exec "killall -9 WeChat"

添加一些便于测试的配置,修改后如下:

ARCHS =armv7 arm64#支持cpu类型TARGET =iphone:latest:8.0#最低支持版本THEOS_DEVICE_IP =192.168.220.195 #手机的ipinclude $(THEOS)/makefiles/common.mkTWEAK_NAME =WXRedTweakWXRedTweak_FILES =Tweak.xmWXRedTweak_FRAMEWORKS =UIKit#需要的框架include $(THEOS_MAKE_PATH)/tweak.mkclean::rm-rf./packages/* after-install::install.exec "killall -9 WeChat"三、查找BaseMsgContentViewController中接收消息的方法 1. 使用logify.pl给BaseMsgContentViewController所有函数添加log /opt/theos/bin/logify.pl /Users/lixingle/Desktop/test/result/Headers/BaseMsgContentViewController.h /Users/lixingle/Desktop/test/result/Tweak/WXRedTweak/wxredtweak/Tweak.xm

执行完以上命令,查看Tweak.xm文件就会发现已经给BaseMsgContentViewController的所有方法添加上了log

1.1 删除影响编译的函数

Tweak项目执行make命令,发现那个函数影响编译先删除。

最终删除的函数有

1.2 编译安装到越狱手机:

1.3在越狱手机上查看log

这里需要另一个手机给这台越狱手机发红包,有女票的可以用女票的手机,没有的用别人女票的,像我这样都没有的只能注册两个微信号了。

在越狱手机终端执行查看log命令tail -f /var/log/syslog | grep WeChat

用另一个手机给这台越狱手机发送一个红包或者文本消息,

多次尝试上一步,查看log有没有规律

在越狱手机终端执行查看log命令tail -f /var/log/syslog | grep WeChat

用另一个手机给这台越狱手机发送一个红包或者文本消息,

多次尝试上一步,查看log有没有规律

经过多次分析 — 删除无用函数 — 编译安装 — 再分析的过程,最后只剩下几个和message相关的函数

根据常识定位到与消息响应相关的方法:

-(void)addMessageNode:(id)arg1layout:(_Bool)arg2addMoreMsg:(_Bool)arg3{ %log; %orig; }四、 查找全局接收消息的方法

我们知道了聊天页面响应消息的方法,下面就需要分析这个方法的调用堆栈,找到那个最顶层接收消息的方法。猜测可能是通知、代理、监听或者管理中心之类机制会在消息到来时告知聊天控制器。那我们应该怎么分析呢?答案就是通过lldb动态调试。

vscode运行vue项目mac(vscode运行vue项目不小心直接关闭vscode)

1. lldb 调试准备

1.1在越狱手机终端中输入

debugserver *:9527 -a "WeChat"

1.2重新打开一个Mac终端,进入lldb后执行

process connect connect://192.168.220.195:9527

2. 分析addMessageNode函数调用堆栈

给-(void)addMessageNode:(id)arg1 layout:(_Bool)arg2 addMoreMsg:(_Bool)arg3方法添加断点,首先要找到该方法的内存地址也就是该函数偏移后的基地址。

偏移后的基地址=偏移前基地址+指令所在模块的ASLR偏移

2.1 查找ASLR偏移地址

在lldb中输入image list -o -f命令,执行结果如下,第一个就是ASLR地址:0x94000

2.2查看偏移前函数基地址

打开IDA或者Hopper,搜索addMessageNode,就可以找到。我用的是IDA反汇编微信的Mach-O文件。下图中标红的位置就是该函数偏移前的基地址:0x0000000101FA957C

所以addMessageNode的内存偏移后地址 = 0x101FA957C + 0x94000 = 0x10203D57C

2.3添加断点

lldb中在0x10203D57C处添加断点br s -a 0x10203D57C,添加成功后,给微信发送一条信息看能不能进断点。

发送一条消息果然进断点了,这时执行bt命令查看调用堆栈如下:

2.4依次把上图中的fame#0 - frame4对应地址翻译成函数名

偏移前基地址 = 偏移后地址 - ASLR偏移地址

frame #0 = 0x000000010203d57c - 0x94000 = 0x101FA957C

frame #1 = 0x00000001022cc920 - 0x94000 = 0x102238920

frame #2 = 0x00000001022b4c38 - 0x94000 = 0x102220C38

frame #3 = 0x0000000104a479a0 - 0x94000 = 0x1049B39A0

frame #4 = 0x0000000102b661dc - 0x94000 = 0x102AD21DC

在lldb中依次查看偏移前基地址对应函数名

0x101FA957C:[BaseMsgContentViewController addMessageNode:layout:addMoreMsg:]

0x102238920:[BaseMsgContentLogicController DidAddMsg:]

0x102220C38:[BaseMsgContentLogicController OnAddMsg:MsgWrap:]

0x1049B39A0:MMCommon`_callExtension + 480 //扩展函数,排除

0x102AD21DC:[CMessageMgr MainThreadNotifyToExt:]

2.5继续查找堆栈中函数

依次在frame0 、1、2、3 、5处添加断点,查看当退出聊天室在其他页面时能否进断点。

经过测试,只有frmae #5: 0x0000000102b661dc处设置的断点,无论在微信任何页面收到红包都能触发断点。

0x0000000102b661dc对应的方法名我们已经在上一步分析到是:[CMessageMgr MainThreadNotifyToExt:],到此我们初步分析到一个收到消息会调用的全局函数[CMessageMgr MainThreadNotifyToExt:]。

五、 分析CMessageMgr类

接下来我们需要分析CMessageMgr看这个名字像是一个消息管理中心,可能离我们要找的全局接收消息的函数不远了。

1. logify分析CMessageMgr

按照第三部logify.pl添加log的方式分析CMessageMgr类。这里我们不在赘述具体步骤。

经过分析log,消息到来时按照先后顺序会依次调用一下10个函数,当然并不是每一个都是接收消息方法。

根据函数名和程序员第七感我们着重分析以下四个函数:

-(void)CheckMessageStatus:(id)arg1Msg:(id)arg2{ %log; %orig; }-(void)AsyncOnPreAddMsg:(id)arg1MsgWrap:(id)arg2{ %log; %orig; }-(void)AsyncOnAddMsg:(id)arg1MsgWrap:(id)arg2{ %log; %orig; }-(void)AsyncOnPushMsg:(id)arg1{ %log; %orig; }

1.1当每次进聊天室时都会调用CheckMessageStatus,所以排除它。

1.2AsyncOnPreAddMsg、AsyncOnAddMsg、AsyncOnPushMsg这三个方法都是在消息到来时触发,从 方法命名AsyncOnPreAddMsg应该是消息的前置处理,AsyncOnPushMsg可能是往队列里面添加消息。 这三个方法都可以用来备选,我们先选AsyncOnAddMsg。

2. 分析AsyncOnAddMsg %hookCMessageMgr-(void)AsyncOnAddMsg:(id)arg1MsgWrap:(id)arg2{NSLog(@"arg1 = %@ , arg2 = %@", arg1, arg2);NSLog(@"arg1 class = %@ , arg2 class = %@", [arg1class], [arg2class]);%orig;}%end

log输出如下:

arg1:NSString

arg2: CMessageWrap

我们也能在头文件中找到CMessageWrap同名的头文件,所以函数声明如下:

-(void)AsyncOnAddMsg:(NSString*)wxidMsgWrap:(CMessageWrap*)wrap;3. 分析CMessageWrap消息内容相关的类

经过分析CMessageWrap头文件和查看不同消息类型的log输出,Tweak最终修改如下:

@interfaceCMessageWrap@property(nonatomic, strong) NSString*m_nsContent;@property(nonatomic, assign) NSIntegerm_uiMessageType;@property(retain, nonatomic) NSString*m_nsFromUsr;@property(retain, nonatomic) NSString*m_nsToUsr;@property(retain, nonatomic) NSString*m_nsAtUserList;@property(retain, nonatomic) NSString*m_nsBizChatId;@property(retain, nonatomic) NSString*m_nsBizClientMsgID;@property(retain, nonatomic) NSString*m_nsDisplayName;@property(retain, nonatomic) NSString*m_nsKFWorkerOpenID;@property(retain, nonatomic) NSString*m_nsMsgSource;@property(retain, nonatomic) NSString*m_nsPattern;@property(retain, nonatomic) NSString*m_nsPushContent;@property(retain, nonatomic) NSString*m_nsRealChatUsr;@end%hookCMessageMgr-(void)AsyncOnAddMsg:(NSString*)wxidMsgWrap:(CMessageWrap*)wrap{%orig;NSIntegeruiMessageType=[wrapm_uiMessageType];NSString*content=[wrapm_nsContent];NSString*nsFromUsr=[wrapm_nsFromUsr];NSString*nsToUsr=[wrapm_nsToUsr];NSString*nsAtUserList=[wrapm_nsAtUserList];NSString*nsBizChatId=[wrapm_nsBizChatId];NSString*nsBizClientMsgID=[wrapm_nsBizClientMsgID];NSString*nsKFWorkerOpenID=[wrapm_nsKFWorkerOpenID];NSString*nsMsgSource=[wrapm_nsMsgSource];NSString*nsDisplayName=[wrapm_nsDisplayName];NSString*nsPattern=[wrapm_nsPattern];NSString*nsRealChatUsr=[wrapm_nsRealChatUsr];NSString*nsPushContent=[wrapm_nsPushContent];NSLog(@"m_uiMessageType=%zd m_nsContent=%@ m_nsFromUsr=%@ m_nsToUsr=%@ m_nsAtUserList=%@ m_nsBizChatId=%@ m_nsBizClientMsgID=%@ m_nsDisplayName=%@ m_nsKFWorkerOpenID=%@ m_nsMsgSource=%@ m_nsPattern=%@ m_nsPushContent=%@ m_nsRealChatUsr=%@",uiMessageType,content,nsFromUsr,nsToUsr,nsAtUserList,nsBizChatId,nsBizClientMsgID,nsDisplayName,nsKFWorkerOpenID,nsMsgSource,nsPattern,nsPushContent,nsRealChatUsr);//记录消息if( 1==uiMessageType){ //普通消息if( 0==nsPushContent.length){if([nsToUsrrangeOfString:@"filehelper"].location!=NSNotFound){NSLog(@"[文件助手: %@]",content);}else{NSLog(@"[我: %@]",content);}}else{NSLog(@"[%@]",nsPushContent);}}elseif( 3==uiMessageType){ //图片消息NSLog(@"收到图片消息");}elseif( 49==uiMessageType){ //红包消息NSLog(@"收到红包消息");}}%end

至此我们已经找到了微信中全局接收消息的方法和红包的类型类型uiMessageType = 49。接下来我们只需要找到抢红包的方法,然后当红包消息到来时自动调用抢红包方法就可以了。

何去何从

万里长征我们迈出了第一步,更难的还在后边。接下来我会用2篇文章讲解怎么反汇编找到抢红包的函数,怎么在设置页面添加一个自动抢红包的开关以及微信的多开。敬请期待...

扫描二维码推送至手机访问。

版权声明:本文由飞速云SEO网络优化推广发布,如需转载请注明出处。

本文链接:http://zspsrg.cn/post/50733.html

分享给朋友:

“vscode运行vue项目mac(vscode运行vue项目不小心直接关闭vscode)” 的相关文章

关于武汉网站建设的信息

关于武汉网站建设的信息

今天给各位分享武汉网站建设的知识,其中也会对进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、在武汉制作一个网站需要多少钱? 2、武汉网站建设公司哪家最好? 3、武汉网站建设哪家公司好? 4、武汉网站建设哪家公司好 5、武汉高端网站建设多少钱?...

深圳做网站推广优化(深圳网站优化公司)

深圳做网站推广优化(深圳网站优化公司)

本篇文章给大家谈谈深圳做网站推广优化,以及深圳网站优化公司对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、急!在深圳做网站SEO优化需要多少钱? 2、选择百度网络排名深圳优化推广公司好在哪里? 3、深圳网站百度排名seo优化推广找什么公司稳妥? 急!在深圳做网站...

百度seo网站优化(SEO优化百度技术网站)

百度seo网站优化(SEO优化百度技术网站)

本篇文章给大家谈谈百度seo网站优化,以及SEO优化百度技术网站对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、百度SEO优化,让网站排名靠前,可以优先选择什么方法? 2、百度seo网站优化怎么做才有效 3、什么是SEO,百度seo优化有哪些方法? 4、百度s...

松江网站建设的简单介绍

松江网站建设的简单介绍

本篇文章给大家谈谈松江网站建设,以及对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、上海猎鹰网络有限公司怎么样?到底是做什么的? 2、上海随牟电子商务有限公司怎么样? 3、上海猫力网络科技有限公司怎么样? 4、松江做网站公司 网站建设,网站策划公司哪家好...

网页设计王者荣耀页面代码(Html制作王者荣耀官网导航条)

网页设计王者荣耀页面代码(Html制作王者荣耀官网导航条)

今天给各位分享网页设计王者荣耀页面代码的知识,其中也会对Html制作王者荣耀官网导航条进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、王者荣耀id空白代码 2、王者荣耀空白代码iOS 3、王者荣耀空白名字代码怎么设置? 4、王者荣耀更新阵容代码...

动态ppt模板下载免费完整版(ppt动态素材库)

动态ppt模板下载免费完整版(ppt动态素材库)

本篇文章给大家谈谈动态ppt模板下载免费完整版,以及ppt动态素材库对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、动态ppt模板百度网盘 2、免费的动态ppt模板怎么下 3、动态ppt模板免费下载 4、PPT模板免费下载的网站哪个好用 动态ppt模板百度网...