为了不让别人说这是小号,特意发一贴,大佬勿喷
本篇主要是介绍一些工作的运用熟练性,以及跟踪堆栈去看是否做一些其他操作等:
抓包:
data:image/s3,"s3://crabby-images/09710/09710f23c30c612f7d717e002ed3e5ca82705d7d" alt=""
signature 为加密值;
data:image/s3,"s3://crabby-images/d22fb/d22fb584a7f20be75bcb414ced0626da07c9b9ab" alt=""
先上trace下堆栈及加密
data:image/s3,"s3://crabby-images/aa733/aa733bbf5fe44553052bf3f89fe5fde11550647a" alt=""
data:image/s3,"s3://crabby-images/67efa/67efa9278904c9d9770f6b802cc8fff5ef069547" alt=""
我们把结果base64下,看结果是否一致,来判断base64是否魔改
data:image/s3,"s3://crabby-images/11aa1/11aa1107ebc9260c5ed2fb5af1e2acffd35418e8" alt=""
data:image/s3,"s3://crabby-images/15042/15042c7813abc47603cc551604a2686146c18e01" alt=""
data:image/s3,"s3://crabby-images/2d3e0/2d3e02b6a50beb9154adafb5156cd038e102d12b" alt=""
验证base64为标准;
根据刚刚的堆栈,跟一下
0x101115468 /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!+[RSA encryptData:withKeyRef:isSign:] 0x101115ae0 /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!+[RSA encryptData:publicKey:] 0x101115a28 /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!+[RSA encryptString:publicKey:] 0x10108a8ac /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!-[YDRequest getSignatureWithReqId:] 0x10108a6b0 /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!-[YDRequest updateParametersForGet:reqid:] 0x10108aaf4 /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!-[YDRequest initWithURLString:parameters:method:] 0x10108e300 /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!-[HpEngineRequest initWithURLString:parameters:method:] 0x101047544 /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!-[HpEngine refreshNewsListOfKeyword:sinceIndex:] 0x101a17858 /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!-[HpNewsListDataProvider userRefreshLatestData:] 0x1017be2ac /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!-[YDNewsListView userRefreshData:] 0x101a235bc /var/containers/Bundle/Application/9580891A-98B0-4F3F-9938-D794221B5B4D/yidian.app/yidian!-[YDNLViewModel didFinishLoadingLocalData:] 0x101a166f0 yidian!0x16ae6f0 (0x1016ae6f0) 0x232360a38 libdispatch.dylib!dispatch_call_block_and_release 0x2323617d4 libdispatch.dylib!dispatch_client_callout 0x23230f008 libdispatch.dylib!_dispatch_main_queue_callback_4CF$VARIANT$mp 0x2328b4b20 CoreFoundation!CFRUNLOOP_IS_SERVICING_THE_MAIN_DISPATCH_QUEUE
data:image/s3,"s3://crabby-images/2a229/2a229f81f48fd5f5285da0a6a2d0fb34003d84cb" alt=""
data:image/s3,"s3://crabby-images/901da/901da7acc45f6cb30dc1998ae6d2377374f2ecab" alt=""
我们再hook下:encryptData:withKeyRef:isSign:
data:image/s3,"s3://crabby-images/b2049/b204989ca46bff6558055b173fff4e12d66969dd" alt=""
frida -UF -l hook.js 直接附加在该app上
var initWithMethod = ObjC.classes.RSA['+ encryptData:withKeyRef:isSign:'];
Interceptor.attach(initWithMethod.implementation, {
onEnter: function (args) {
// console.log('initWithMethod called from:\n' +
// Thread.backtrace(this.context, Backtracer.ACCURATE)
// .map(DebugSymbol.fromAddress).join('\n') + '\n');
console.log("args[2]: ", ObjC.Object(args[2]));
console.log("args[3]: ", hexdump(args[3]));
console.log("args[4]: ", args[4]);
}, onLeave: function (retval) {
console.log('Base64Encode() this.args1 onLeave:', hexdump(retval));
}
});
bool a5为 0,也就是false, 直接走
data:image/s3,"s3://crabby-images/b4e37/b4e37965821abd6f28f2717bac8af24aa55181c8" alt=""
data:image/s3,"s3://crabby-images/79e24/79e24b82921220cfc32fe9ea7529fd25483cf6c1" alt=""
这个时候就明白了吧,这个地方就是上面的 最开始trace下堆栈及加密的地方了。
根据堆栈再往上看下吧:
data:image/s3,"s3://crabby-images/dbf56/dbf5614467ce9a7f05b035f94f513b9f2a307bf0" alt=""
data:image/s3,"s3://crabby-images/7f7a4/7f7a4a78c1fed8416868602a72118839fec032b6" alt=""
看到这里也是做了rsa然后base64, 没有其他操作
我们hook下吧:
var initWithMethod = ObjC.classes.RSA['+ encryptString:publicKey:'];
Interceptor.attach(initWithMethod.implementation, {
onEnter: function (args) {
// console.log('initWithMethod called from:\n' +
// Thread.backtrace(this.context, Backtracer.ACCURATE)
// .map(DebugSymbol.fromAddress).join('\n') + '\n');
console.log("args[2]: ", ObjC.Object(args[2]));
console.log("args[3]: ", ObjC.Object(args[3]));
console.log("args[4]: ",hexdump(args[4]));
}, onLeave: function (retval) {
console.log('Base64Encode() this.args1 onLeave:', ObjC.Object(retval));
}
});
data:image/s3,"s3://crabby-images/5822e/5822ee912df9ce793386e4859960e1e3c49ceeda" alt=""
data:image/s3,"s3://crabby-images/4592d/4592d13e3c49329067f60930e5c4bc588d8c4a41" alt=""
我去,这不就直接出来了吗
需要加密的值 :"pro6.4.0.00njbh2wlr_1685327378963_38033100" 入参拼接 appid、cv、platform、reqid、version
更多【[某点资讯Signature逆向]】相关视频教程:www.yxfzedu.com