Android逆向之以调试方式启动App

在逆向时有时不可避免需要调试app,比如调试so。

一般调试so有两种方式:

    方式1:app已经启动运行了,使用调试器比如IDA附加到app进程上调试进行调试。

    方式2:以调试方式启动app, 被调试app启动时会弹出一个框,等待调试器来附加。

如果app有些功能是在app启动时完成的,那么我们需要选择方式2来调试,因为方式1,app已经启动运行了,相应的代码可能已经执行完了。

很久没有调试App,很多步骤都不记得了。为了复习下调试步骤,也希望能帮助到刚接触到无源码调试App的新同学。特意写下这边文章,记录下调试过程。


一、新建一个Android项目(注意是新的项目,不是新建一个Module),勾选Include C++ suppot。因为我打算调试下so


说明:

1 因为勾选了Include C++ support IDE会自动生成jni的代码。

2 模块的build.gradle部分参数如下:


这只是一个练习Demo,所以使用了-O0选项,禁止编译器优化C/C++代码,另外只生成32位arm汇编

3 对App进行了签名


对app进行签名,只是为了模拟正常的逆向app,因为逆向时的app肯定是签名过的 

4 minifest中并没有debugable = true属性。添加这个只是为了证明。如果你的手机是debug版本的,所有的app都是可以调试的


只要手机是debug版本的,那么所有的app都是可以调试的。在windows下执行adb shell getprop | findstr debuggable,

 看输出:[ro.debuggable]: [1] , 1 表示手机是可以调试的


二、编译得到签名后的没有debugable的app,截图如下:


三、安装app


app安装成功了

四、以调试方式启动app

1 执行 adb shell am start -D -n com.reverse.debug/com.reverse.debug.MainActivity

执行上述命令后,app启动,并弹框如下:


等待调试器来附加,当调试器附加上之后,这个框自动消失

2 此时在cmd中执行,monitor.bat脚本。安装了AndrodStudio都有这个脚本。执行这个脚本启动DDMS,并选中要调试的App。

选中后可以看到左边边有个虫子的ICON。右边显示8700端口。我们用这个端口来附加java调试器

注意:执行monitor.bat脚本前,前先关闭Android Studio。否则会有冲突。我也搞不懂为什么会这样

3 cmd中执行jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=8700

使用jdb调试器,附加到调试app上,执行这一步后,前面弹出的提示框就没有了。其实在第一步执行:adb shell am start -D -n com.reverse.debug/com.reverse.debug.MainActivity 程序是暂停在ActivityThread.java的如下代码处,等待调试器。当执行jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=8700后,调试器附加上了,waitForDebugger返回,程序可以继续执行。进入正常的app启动流程



总结:

    通过这个小测试,我们可以看到,一个app,不管你是什么版本的,release/debug,不管你minifest是否有debugale属性。只要手机是debug版本的。那么这个app都可以被调试。要获得一个debug版本的手机,通常需要编译源码刷机。验证是否是debug版本的手机可以执行如下命令:

    adb shell getprop | findstr debuggable。

    另外执行jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=8700命令时正常的输出是:


如果提示如下东西:

java.net.ConnectException: Connection refused: connect

        at java.net.DualStackPlainSocketImpl.connect0(Native Method)

        at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:79)

        at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)

        at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)

        at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)

        at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172)

        at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)

        at java.net.Socket.connect(Socket.java:589)

        at com.sun.tools.jdi.SocketTransportService.attach(SocketTransportService.java:222)

        at com.sun.tools.jdi.GenericAttachingConnector.attach(GenericAttachingConnector.java:116)

        at com.sun.tools.jdi.SocketAttachingConnector.attach(SocketAttachingConnector.java:90)

        at com.sun.tools.example.debug.tty.VMConnection.attachTarget(VMConnection.java:519)

        at com.sun.tools.example.debug.tty.VMConnection.open(VMConnection.java:328)

        at com.sun.tools.example.debug.tty.Env.init(Env.java:63)

        at com.sun.tools.example.debug.tty.TTY.main(TTY.java:1082)

致命错误:

无法附加到目标 VM。


请先关闭android studio,执行monitor.bat脚本,启动ddms。选中要调试的进程。再执行:jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=8700。网上部分文章漏了这一步,大家要注意下。


后记:

之前一直要用DDMS选中那个进程,然后才能jdb connect成功。最近在android官网看到一篇文章:

https://source.android.google.cn/devices/tech/debug/gdb。发现可以不执行monitor.bar脚本。无需启动DDMS。

新的已调试方式启动App方法如下:

linxu环境下执行:

1 adb shell am start -D -n com.reverse.debug/com.reverse.debug.MainActivity (以调试方式启动,App弹框等待调试器)

2 adb shell ps | grep debug  输出信息如下。

u0_a67        4920  639 1628988  29612 futex_wait_queue_me 0 S com.reverse.debug

3 adb forward tcp:12345 jdwp:4920   //4920是进程ID

4 jdb -attach localhost:12345

输出如下:

Set uncaught java.lang.Throwable

Set deferred uncaught java.lang.Throwable

Initializing jdb ...

>


执行完步骤四,java调试器附加上去了。App弹框消失


windows环境下类似(最后一步有点区别):

1 adb shell am start -D -n com.reverse.debug/com.reverse.debug.MainActivity

2 adb shell ps | findstr debug 输出如下

u0_a67 4965 639 1628988 29636 futex_wait_queue_me 0 S com.reverse.debug

3 adb forward tcp:12345 jdwp:4965

jdb -connect com.sun.jdi.SocketAttach:hostname=127.0.0.1,port=12345

采用这种方式,不需要去启动DDMS,选中要调试的进程。感觉更简单些。而且不用关闭AndrodStudio。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354

推荐阅读更多精彩内容