切换风格

默认Lavender Sky Flowers Wizard Snow Beige California City Dragon Black London Sunset glow Pink Cloud
12下一页

28

主题

278

积分

3

精华

用户组 

易积分
33123
热心
2
好评
29

热心会员

APP脱壳,适用于360、腾讯等各大主流加密平台[复制链接]
发表于 2018-5-6 22:57:48 | 显示全部楼层 |阅读模式
本贴介绍如何使用xposed框架编写插件来脱app加固的壳。


无意间了解一篇文章介绍了dumpdex,GitHub地址:https://github.com/a813630449/dumpDex
当时心情十分的激动,总算找到一个对我非常有用的项目了。
然后参考了下代码,思路大概是这样的:
一、过滤掉其他应用,只处理360加固、腾讯乐加固这些等。
二、hook Classloader的loadClass(String,boolean) (注意:loadclass(String)函数里最终也还是调用loadClass(String,boolean))
三、获取到hook loadcalss函数返回的Class对象
四、反射调用java.lang.Class的getDex方法,获取到对象
五、反射调用Dex对象的getBytes方法,取到字节集。
六、将字节集流写出到存储卡中。
看完思路后,迫不及待的去试了。
然而并没有想象中的那样,需要脱壳的应用卡爆了,直接报ANR(应用程序无响应)异常。
然后我回过头来,看着代码,不断地调试发现:
Classloader的loadClass(String,boolean)方法被调用了几千次!!!
其中我又调试输出这些class的名称
结果又发现,非常多与之无关的class!!!!
所以过滤下就行了,而且只执行一次就可以。
完整的代码贴下:
  1. package com.wrbug.dumpdex;

  2.         import android.os.Environment;

  3.         import com.example.admin.myapplication.BuildConfig;
  4.         import com.example.admin.myapplication.MainActivity;

  5.         import java.io.File;
  6.         import java.lang.reflect.Field;
  7.         import java.lang.reflect.Method;

  8.         import de.robv.android.xposed.IXposedHookLoadPackage;
  9.         import de.robv.android.xposed.XC_MethodHook;
  10.         import de.robv.android.xposed.XposedBridge;
  11.         import de.robv.android.xposed.XposedHelpers;
  12.         import de.robv.android.xposed.callbacks.XC_LoadPackage;

  13. /**
  14. * XposedInit
  15. *
  16. * @author wrbug
  17. * @since 2018/3/20
  18. */
  19. public class XposedInit implements IXposedHookLoadPackage {

  20.     private Method getBytesMethod;
  21.     private Method getDexMethod;


  22.     /**
  23.      * 加固应用包含的包名,如果无法脱壳,请将application的包名,加到此数组
  24.      * com.stub.StubApp 360加固
  25.      * s.h.e.l.l.S 爱加密
  26.      * com.secneo.apkwrapper.ApplicationWrapper 梆梆加固
  27.      * com.tencent.StubShell.TxAppEntry 腾讯加固
  28.      */
  29.     private String[] packages = {"com.stub.StubApp", "s.h.e.l.l.S",
  30.             "com.secneo.apkwrapper.ApplicationWrapper", "com.tencent.StubShell.TxAppEntry"};

  31.     public static void log(String txt) {
  32.         if (!BuildConfig.DEBUG) {
  33.             return;
  34.         }
  35.         XposedBridge.log("dumpdex-> " + txt);
  36.     }

  37.     public static void log(Throwable t) {
  38.         if (!BuildConfig.DEBUG) {
  39.             return;
  40.         }
  41.         XposedBridge.log(t);
  42.     }

  43.     @Override
  44.     public void handleLoadPackage(final XC_LoadPackage.LoadPackageParam lpparam) {
  45.         Class<?> clazz = null;
  46.         for (String aPackage : packages) {
  47.             clazz = XposedHelpers.findClassIfExists(aPackage, lpparam.classLoader);
  48.             if (clazz != null) {
  49.                 log("find class:" + aPackage);
  50.                 FileUtils.writeByteToFile("2".getBytes(), Environment.getExternalStorageDirectory().getPath()+"/1.dex");
  51.                 break;
  52.             }
  53.         }
  54.         if (clazz == null) {
  55.             return;
  56.         }
  57.         final String packageName = lpparam.packageName;
  58.         XposedBridge.log(packageName);
  59.         try {
  60.             initDexMethod();
  61.         } catch (Throwable t) {
  62.             //Android版本不支持该插件
  63.             log(t);
  64.             return;
  65.         }
  66.         XposedHelpers.findAndHookMethod("java.lang.ClassLoader", lpparam.classLoader, "loadClass", String.class, boolean.class, new XC_MethodHook() {
  67.             @Override
  68.             protected void afterHookedMethod(MethodHookParam param) throws Throwable {
  69.                 Class c = (Class) param.getResult();

  70.                 if (c == null) {
  71.                     return;
  72.                 }
  73.                 Object object = getDexMethod.invoke(c);
  74.                 byte[] array = (byte[]) getBytesMethod.invoke(object);
  75.                 if (array == null) {
  76.                     return;
  77.                 }
  78.                 if (param.args[0].toString().startsWith("com.newapp")){
  79.                     saveData(packageName, array);
  80.                     log("dump dex :" + param.args[0]);
  81.                 }
  82.             }
  83.         });
  84.     }
  85.     public boolean isone=false;
  86.     private void saveData(String packageName, byte[] array) {
  87.         if (isone){
  88.             return;
  89.         }
  90.         String path = Environment.getExternalStorageDirectory().getPath();
  91.         File parent = new File(path);
  92.         if (!parent.exists() || !parent.isDirectory()) {
  93.             parent.mkdirs();
  94.         }
  95.         File file = new File(path, "source-" + array.length + ".dex");
  96.         if (!file.exists()) {
  97.             FileUtils.writeByteToFile(array, file.getAbsolutePath());
  98.             //XposedHelpers.callStaticMethod(MainActivity.class,"setArray",byte[].class,array);

  99.             log("dump dex :" + file.getAbsolutePath());
  100.             isone=true;
  101.         }
  102.     }

  103.     public void initDexMethod() throws ClassNotFoundException, NoSuchMethodException {
  104.         Class dex = Class.forName("com.android.dex.Dex");
  105.         this.getBytesMethod = dex.getDeclaredMethod("getBytes");
  106.         this.getDexMethod = Class.forName("java.lang.Class").getDeclaredMethod("getDex");
  107.     }
  108. }
复制代码
注意几点:

1、开发请先搭建xposed环境
2、如果无法脱壳,请将该应用的加密壳的application添加到packages数组中
3、过滤那将com.newapp替换成你需要脱壳的app package

易如意中文编程学习交流论坛有你更精彩~
回复

使用道具 举报

13

主题

317

积分

0

精华

用户组 

易积分
1351
热心
0
好评
2
发表于 2018-5-6 23:36:40 | 显示全部楼层
表示文字看不透,xp已建好,等视频教程
易如意中文编程学习交流论坛有你更精彩~
回复

使用道具 举报

0

主题

4

积分

0

精华

用户组 

易积分
14
热心
0
好评
0
发表于 2018-5-7 00:35:46 | 显示全部楼层
感谢分享啊
易如意中文编程学习交流论坛有你更精彩~
回复

使用道具 举报

35

主题

1172

积分

0

精华

用户组 

易积分
220
热心
9
好评
0

热心会员活跃会员

发表于 2018-5-7 08:38:10 | 显示全部楼层
看不懂
回复

使用道具 举报

14

主题

1514

积分

0

精华

用户组 

易积分
844
热心
0
好评
1
发表于 2018-5-7 23:01:53 | 显示全部楼层
支持一个!!!!!!!!!
易如意中文编程学习交流论坛有你更精彩~
回复

使用道具 举报

1

主题

69

积分

0

精华

用户组 

易积分
177
热心
0
好评
0
发表于 2018-5-18 09:34:45 | 显示全部楼层
表示不是很懂,希望大神出视频教程
易如意中文编程学习交流论坛有你更精彩~
回复

使用道具 举报

25

主题

223

积分

0

精华

用户组 

易积分
2631
热心
0
好评
1
发表于 2018-5-23 10:35:54 | 显示全部楼层
这么叼的吗??
一个大佬的博客http://suo.im/50PPMP
回复

使用道具 举报

3

主题

115

积分

0

精华

用户组 

易积分
493
热心
0
好评
0
发表于 2018-6-25 12:05:37 | 显示全部楼层
看不懂 也要回复一下
易如意中文编程学习交流论坛有你更精彩~
回复

使用道具 举报

2

主题

70

积分

0

精华

用户组 

易积分
295
热心
0
好评
0
发表于 2018-6-25 12:40:45 | 显示全部楼层
支持一个!!!!!!!!!
易如意中文编程学习交流论坛有你更精彩~
回复

使用道具 举报

10

主题

594

积分

0

精华

用户组 

易积分
122
热心
0
好评
0
发表于 2019-9-17 14:22:09 | 显示全部楼层
怀特 uuteu
易如意中文编程学习交流论坛有你更精彩~
回复

使用道具 举报

QQ|sitemap|免责声明|RGB颜色对照表|手机版|小黑屋| 易如意 - E4A中文编程学习交流论坛

GMT+8, 2024-4-26 21:34 , Processed in 0.057247 second(s), 35 queries .

Powered by Discuz! X3.4

© 2001-2018 eruyi.cn

返回顶部