hzwsuki 发表于 2021-2-9 22:04

IOS微信逆向-免越狱抢红包防撤回等自定义功能实现

本帖最后由 hzwsuki 于 2021-2-17 13:24 编辑

#

## 环境

| 环境                                              | 版本               |
| :------------------------------------------------ | :------------------- |
| 操作系统                                          | MacOS Mojave 10.14.6 |
| 手机系统                                          | Iphone6 IOS12      |
| mac上面的 (https://github.com/theos/theos) | 最新版               |
| xcode                                             | 11.3.1               |
| MonkeyDev                                       |                      |

## 效果

微信步数

防撤回

自动抢红包


##微信砸壳

CrackerXI+砸壳,或手动使用dumpdecrypted砸壳

这里我使用的微信版本是8.0.0


使用scp或者助手把已砸壳的wechat.ipa导出


## monkeydev

MonkeyDev集成在xcode上面,可以快速开发hook的代码,链接到Mach-O文件,支持修改ipa后的免越狱安装。

新建MonkeyDev项目


把砸壳后的微信ipa拖进工程中的TargetApp目录

run编译真机调试

打开微信设置页面,xcode打开Debug View Hierarychy查看层级。


新增控件类WCTableViewManager

```objective-c
%hook NewSettingViewController
- (void)reloadTableData{
    %orig;
    WCTableViewManager *tableViewMgr = MSHookIvar<id>(self, "m_tableViewMgr");
    MMTableView *tableView = ;
    WCTableViewNormalCellManager *newCell = [%c(WCTableViewNormalCellManager) normalCellForSel:@selector(setting) target:self title:@"你懂的"];
    [((WCTableViewSectionManager*)tableViewMgr.sections) addCell: newCell];
    ;
}

%new
- (void)setting {
    UIViewController *vc = [ init];
    [((UIViewController *)self).navigationController PushViewController:vc animated:true];
}

%end
```

新增自动抢红包、消息防撤回、微信步数修改选项

```objective-c
    WCTableViewCellManager *autoEnvelopCell = ];
    ;

    WCTableViewCellManager *revokeIntercept = ];
    ;

    WCTableViewCellManager *changeStepsCell = ];
    ;
```


hook红包消息实现自动抢

```objective-c
BOOL (^shouldReceiveRedEnvelop)() = ^BOOL() {
                  if (!HZWechatConfig.autoRedEnvelop) { return NO; }
                  if (isGroupInBlackList()) { return NO; }
                  if (isContaintKeyWords()) { return NO; }
                  return isGroupReceiver() ||
                           (isGroupSender() && isReceiveSelfRedEnvelop()) ||
                           (!isGroupReceiver() && HZWechatConfig.personalRedEnvelopEnable);
                };

                NSDictionary *(^parseNativeUrl)(NSString *nativeUrl) = ^(NSString *nativeUrl) {
                  nativeUrl = ];
                  return [%c(WCBizUtil) dictionaryWithDecodedComponets:nativeUrl separator:@"&"];
                };

```

防撤回实现

```objective-c
%hook CMessageMgr
- (void)onRevokeMsg:(CMessageWrap *)arg1 {

    if (HZWechatConfig.preventRevoke) {
      NSString *msgContent = arg1.m_nsContent;

      NSString *(^parseParam)(NSString *, NSString *,NSString *) = ^NSString *(NSString *content, NSString *paramBegin,NSString *paramEnd) {
            NSUInteger startIndex = .location + paramBegin.length;
            NSUInteger endIndex = .location;
            NSRange range = NSMakeRange(startIndex, endIndex - startIndex);
            return ;
      };

      NSString *session = parseParam(msgContent, @"<session>", @"</session>");
      NSString *newmsgid = parseParam(msgContent, @"<newmsgid>", @"</newmsgid>");
      NSString *fromUsrName = parseParam(msgContent, @"<![CDATA[", @"撤回了一条消息");
      CMessageWrap *revokemsg = ];

      CContactMgr *contactMgr = [ getService:objc_getClass("CContactMgr")];
      CContact *selfContact = ;
      NSString *newMsgContent = @"";


      if () {
            if (revokemsg.m_uiMessageType == 1) {       // 判断是否为文本消息
                newMsgContent = ;
            } else {
                newMsgContent = @"拦截到你撤回一条消息";
            }
      } else {
            if (revokemsg.m_uiMessageType == 1) {
                newMsgContent = ;
            } else {
                newMsgContent = ;
            }
      }

      CMessageWrap *newWrap = ({
            CMessageWrap *msg = [[%c(CMessageWrap) alloc] initWithMsgType:0x2710];
            ;
            ;
            ;
            ;
            ];

            msg;
      });

      ;
      return;
    }
    %orig;
}

%end
```

修改微信运动步数

```objective-c
%hook WCDeviceStepObject
-(NSInteger)m7StepCount {
    NSInteger stepCount = %orig;
    NSInteger newStepCount = HZWechatConfig.changedSteps;

    return HZWechatConfig.changeSteps ? newStepCount : stepCount;
}

-(NSInteger)hkStepCount {
    NSInteger stepCount = %orig;
    NSInteger newStepCount = HZWechatConfig.changedSteps;

    return HZWechatConfig.changeSteps ? newStepCount : stepCount;
}

%end
```

自签名打包后实现多开,配合AltDeploy+AltStore食用更佳



附上未签名版ipa,仅供学习研究使用,切勿用作非法用途!
需要自己使用爱思或者其他自签工具
自签流程参考:下载itunes ,tunes里面有一个账户,先登陆你的id,然后授权这个电脑,然后用这个id登陆itunes里面的商店.保持itunes不关闭,打开爱思,然后用刚刚的id签名


## 感谢
MonkeyDev
WeChatRedEnvelop
iOS应用逆向与安全之道

## 最后

新年快乐

linbiliu 发表于 2021-2-15 20:54

建议加一个Callkit功能,其次方便粉丝安装

慵懒丶L先森 发表于 2021-2-10 02:52

膜拜,虽然看完后,脑子告诉我会了,但是手告诉我不行。关于环境的问题,虚拟机可以解决,但是这教程还是过于简化了,再详细一点就好了,特别是后面的重签名的问题,还是感谢分享

璐璐诺 发表于 2021-2-9 22:29

大佬 有成品吗 小弟我看不懂这操作a.。。。

hzwsuki 发表于 2021-2-10 10:43

慵懒丶L先森 发表于 2021-2-10 02:52
膜拜,虽然看完后,脑子告诉我会了,但是手告诉我不行。关于环境的问题,虚拟机可以解决,但是这教程还是过 ...

重签名的话i4、Sideloadly、AltDeploy+AltStore都行

MisS 发表于 2021-2-9 22:22

虽然没看懂,但是觉得很牛逼的感觉。。。

Flyi 发表于 2021-2-9 22:11

厉害了会小黑屋嘛

重九先生 发表于 2021-2-9 22:11

我想知道你是怎么安的第二个微信

沧海神月 发表于 2021-2-9 22:33

这个就很厉害了{:1_921:}

lvjoker 发表于 2021-2-9 22:34

大佬,求个成品·!这样TX会不会检测到封号的?

淡淡不揩油i 发表于 2021-2-9 22:41

求个成品。。

m0216 发表于 2021-2-9 22:42

求个成品{:1_918:}

qiyx 发表于 2021-2-9 22:43

大神求个成品~
页: [1] 2 3 4 5 6 7 8 9 10
查看完整版本: IOS微信逆向-免越狱抢红包防撤回等自定义功能实现