结合AI对WhatsApp的分析 (一)

一、目标

1:main

好希望未来的世界是这样的:

javascript 复制代码
小X同学,请帮我写一个ws的H算法,并且详细解释入参和结果。

可惜现实是这样的

1:ws1

也好,起码飞哥还不至于失业,李老板还得老老实实给我发工资。然后含泪退掉了他偷偷买的4090,原计划他准备搭个DeepSeek来优化我的。

二、步骤

遇事不决先问AI

工具是死的,人是活到。个人认为目前的AI,抹平了初级程序员和中级的程序员之间的技术差距。但是抹平不了李老板和入门级的程序员之间的技术差距。

作为一个有证的程序员,应该这样问AI才靠谱

1:ws2

这里面的关键信息就是 AES SHA256 和 libwhatsapp.so 了,

找朋友 libwhatsapp.so

我们遇到的第一个困难就是, 最新版的apk里面只有libsuperpack.solibunwindstack.so, 并没有我们期待的 libwhatsapp.so

不过这也难不倒我们,继续问AI呗。这次 AI给出了几个方案,它怀疑 WhatsApp 可能已经将多个 .so 库合并进一个单独的 libsuperpack.so 文件,减少 APK 体积并提高加载效率。

所以我们先安装Apk,然后用上最原始的查找大法

javascript 复制代码
find / -name 'libwhatsapp.so' -type f

  


# 结果出来了

/data/user/0/com.whatsapp/files/decompressed/libs.spo/libwhatsapp.so

IDA

这个 H 一看就是个Base64, 所以第一反应就是 hook java的 base64函数,但是没有结果,那就说明大概率是在 so里面做的base64。

这时候就请IDA上场了。

我感觉下一个版本的ida可能就会增加AI窗口了, 咱们直接输入一个:

javascript 复制代码
请帮我标出这个so中做Base64操作的函数,并且生成frida Hook的代码

好吧,在ida没有更新之前,只能飞哥上场了。

挂上心爱的 FindCrypt插件

1:ida1

啥也不说了,先Hook它

javascript 复制代码
let libWhatsAppAddress = Module.findBaseAddress('libwhatsapp.so');

console.log(" ==> libwhatsapp : " + libWhatsAppAddress)

  


let offset = 0x89F7C8;

let funcAddr = libWhatsAppAddress.add(offset);

Interceptor.attach(funcAddr, {

onEnter: function(args) {

},

onLeave: function(retval) {

  


console.log('--> retval: ' + retval);

try {

let strIn = Memory.readUtf8String(retval);

console.log(strIn);

} catch (e) {

Log( "#### Base64 A Rc Error");

}

  


console.log(`/* TID ${gettid()} */ ======= Base64 A retval ====`);

}

});

跑一下 ,熟悉的味道

1:rc1

三、总结

再强调一遍,以后的程序员只会有一种,利用辅助AI工具的程序员。不会使用AI的程序员一定是要被淘汰的。

早用早享受,不用担心AI会替代你,AI的出现只会让你的工作更加高效。以此为理由找李老板提加工资。

1:ffshow

这台机器不会取代我们任何一个人

Tip:

: 本文的目的只有一个就是学习更多的逆向技巧和思路,如果有人利用本文技术去进行非法商业获取利益带来的法律责任都是操作者自己承担,和本文以及作者没关系,本文涉及到的代码项目可以去 奋飞的朋友们 知识星球自取,欢迎加入知识星球一起学习探讨技术。有问题可以加我wx: fenfei331 讨论下。

相关推荐
tangweiguo0305198720 分钟前
Kotlin高效实现 Android ViewPager2 顶部导航:动态配置与性能优化指南
android·kotlin
fantasy_41 小时前
Appium高级操作--ActionChains类、Toast元素识别、Hybrid App操作、手机系统API的操作
android·python·appium·自动化
二流小码农1 小时前
鸿蒙开发:自定义一个Toast
android·ios·harmonyos
雾里看山1 小时前
【MySQL】用户管理和权限
android·mysql·adb
_祝你今天愉快2 小时前
Android源码学习之Overlay
android·源码
顾林海2 小时前
Flutter Dart 异常处理全面解析
android·前端·flutter
獨枭2 小时前
Mac 上 Android Studio 的安装与配置指南
android·macos·android studio
rainboy3 小时前
对Parcelable/Serializable的一点理解
android·java·源码
程序视点4 小时前
为什么你的 AI 助手总是答非所问?
aigc·deepseek·ai 编程
顾林海4 小时前
Android线程与线程池:高效编程的基石
android