-
-
[原创]某宝千牛浏览器开启远程调试
-
发表于:
2023-9-1 14:07
12117
-
Chrome 的远程调试端口一般可以通过命令行参数进行开启, --remote-debugging-port=9222。但千牛的浏览器是通过程序代码启动的,加命令行参数行不通。
1. 查看安装目录有 libcef.dll 文件,标出了 cef 的版本,文件大小有 127 MB,cef 大部分的代码应该都在这里。数字签名是淘宝的,应该经过了重新编译。
2. 直接上 x32 dbg,调试 AliWorkbench.exe,会出现反调试,程序会退出。使用 x32 dbg 的 调试——》高级——》隐藏调试器(PEB)也不行。
3. 打开 ProcessExplorer ,查看程序的命令行参数,看到 AliApp.exe 进程的命令行参数,有点眼熟,像是传给 cef 的。
4. 通过调试知道千牛是使用 C++ 写的,然后就去搜索 C++ 的 cef 的源代码,在这里找到了
https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding,然后 clone 一份到本地。
5.使用 notepad++ 打开, Open Folder as Workspace,右击根目录搜索 remote_debugging_port,成功搜到一个地方,并且只有这一个地方是赋值的。
6. 如果能在内存当中定位到这个地方,事情就简单了。这个赋值的前后没有一些字符串可以搜索,只有大段的 cef_string_set,通过搜索 cef_string_set,定位到了 3 个宏定义。
7. 上 x32 dbg 调试 AliApp.exe,上面找到的 3 个函数,直接在符号列表里能看到,全部下断点。
8. 命中断点后,通过 调用堆栈 找上一层函数,成功定位到一个方法,和需要找的很像,往下一些位置,猜测就是 remote_debugging_port 的赋值。
9. 通过按地址查看 esi 的值,更是坚信了找的位置是正确的,这个结构体正是 cef_settings。
10. 选中以上两行,右击——》汇编,修改为 mov dword ptr ds:[edi+0xC8],10000,调试端口是 10000,勾选剩余字节用 NOP 填充。
11. 修改后的汇编是这样的。
12. 让代码执行完,在 句柄 界面成功看到监听端口 10000。
[培训]《安卓高级研修班(网课)》月薪三万计划,掌握调试、分析还原ollvm、vmp的方法,定制art虚拟机自动化脱壳的方法
最后于 2023-9-12 15:45
被kanxue编辑
,原因: