一.安装smalidea
https://github.com/JesusFreke/smali/wiki/smalidea
1. 进入IntelliJ IDEA/Android Studio开始安装插件,进入Settings->Plugins点击Install plugin from disk选中下载好的压缩包
2. apply->restart Android Studio
3. 该调试方法的原理
采用 hook 方式达到开启所有应用调试的目的,xposed 插件代码如下
publicclassDebugimplementsIXposedHookLoadPackage {
public boolean debugApps =true;
public static final int DEBUG_ENABLE_DEBUGGER =0x1;
public String tag ="IDG";
@Override
public void handleLoadPackage(XC_LoadPackage.LoadPackageParam lpparam )throwsThrowable {
if (lpparam.appInfo ==null||
(lpparam.appInfo.flags & (ApplicationInfo.FLAG_SYSTEM | ApplicationInfo.FLAG_UPDATED_SYSTEM_APP)) !=0){
return;
}
tag = tag + lpparam.packageName;
XposedBridge.hookAllMethods(Process.class,"start",newXC_MethodHook() {
@Override
protected void before HookedMethod(MethodHookParam param) throwsThrowable {
intid =5;
intflags = (Integer) param.args[id];
Log.d(tag,"flags is : "+flags);
if(debugApps) {
if((flags & DEBUG_ENABLE_DEBUGGER) ==0) {
flags |= DEBUG_ENABLE_DEBUGGER;
}
}
param.args[id] = flags;
Log.d(tag,"flags changed : "+flags);
}
});
}
}
二.安装调试工具
安装Xposed框架
1.下载相关工具
XposedInstaller下载
http://repo.xposed.info/module/de.robv.android.xposed.installer
XposedBridged.jar下载
https://github.com/rovo89/XposedBridge/releases
2.安装XposedInstaller并激活
激活步骤: 启动XposedInstaller -> 框架 -> 安装更新 ->模拟器重启 (ps:模拟器会直接屏幕黑掉,直接结束进程即可,不行就反复试几下 )
激活后这里会有绿色的数字信息
data:image/s3,"s3://crabby-images/f0665/f06658827cfea285d1af1c450e5d197210d16e79" alt=""
安装XInstaller
1.XInstaller下载地址
XInstaller源码
https://github.com/pylerSM/XInstaller
XInstaller APK下载
http://repo.xposed.info/module/com.pyler.xinstaller
2.安装后启动一下,并在Xposed的模块中勾选,重启系统
data:image/s3,"s3://crabby-images/a68ec/a68ec47692f12da387fd1662fce72c0d7e8ead25" alt=""
3.配置XInstaller
3.1启动砖家模式
data:image/s3,"s3://crabby-images/fd8d2/fd8d289d5ab8ba4ff476c110a433afb58a966f6a" alt=""
3.2设置调试应用
其他设置->调试应用
data:image/s3,"s3://crabby-images/ad578/ad57823543982101dd024382a3f16312cd0723b3" alt=""
三.项目设置
1.生成smali文件
baksmali-2.0.5.jar 360.apk -o 360/projects/360/src
2.Android Studio导入项目
启动Android Studio->File->New->Import Project
选择上面生成的路径,选定src的上层目录
data:image/s3,"s3://crabby-images/45b81/45b81b13744c46fbd40d78fbea9c91fa8958015c" alt=""
选择Create Project from existing sources
data:image/s3,"s3://crabby-images/634f3/634f34c635ded6487b8a7c6d6316f7be55e6e2ba" alt=""
选择Make Directory AS->Sources Root
data:image/s3,"s3://crabby-images/81056/81056f61e797da25748a6d479a9f627a26c0e99f" alt=""
File->Project Structure 选择对应的SDK版本
data:image/s3,"s3://crabby-images/4e2d4/4e2d454ca42e48807c75dc6a90e013cb3d26df60" alt=""
配置调试选项
Run->Edit Configurations
data:image/s3,"s3://crabby-images/e33ee/e33ee9c9811ce794953f44cf4b6992361a32b74c" alt=""
四.开始调试
1. 方法一: 使用DDMS进行调试(一定要开启DDMS)
真机
a.勾选USB调试
b勾选USB调试通知
c.在开发者选项中->选择调试的应用->选择你要调试的程序->勾选等待调试器
d.启动程序,程序会停在等待调试器界面
此时ddms可以看到
data:image/s3,"s3://crabby-images/52836/52836321eff66b1f810e4297dd4245e08cb7f552" alt=""
Android Studio中对代码下好断点->Run->Debug->DebugOnly即可开始调试
Console控制台输出
Connected to the target VM, address: 'localhost:8700', transport: 'socket'
调试截图如下:
data:image/s3,"s3://crabby-images/c47bd/c47bdfd33d1edd1bd841ce0b22d488338574fb51" alt=""
2. 方法二:使用adb调试
在AndroidManifest.xml得到主Activity如下:
com.qihoo.antivirus.desktopclean.ui.DesktopQuickCleanActivity
调试启动目标程序
adb shell am start -D -W -n com.qihoo.antivirus/.desktopclean.ui.DesktopQuickCleanActivity
设置端口转发
adb shell ps | grep antivirus
u0_a36 5766 154 907116 29496 ffffffff b7544d11 S com.qihoo.antivirus
adb forward tcp:8700 jdwp:5766
data:image/s3,"s3://crabby-images/3489f/3489f317c702f8d2487f7ffc7c5078399997300f" alt=""
PS:使用Windows自带的cmd将会找不到grep, 如果一定要用cmd,可以把cygwin和mingw64的路径添加到环境变量
Android Studio中对代码下好断点->Run->Debug->DebugOnly即可开始调试
实际测试方法二Droid4x上可以断下来
网友评论