码迷,mamicode.com
首页 > 移动开发 > 详细

android apk壳

时间:2015-09-16 17:56:41      阅读:220      评论:0      收藏:0      [点我收藏+]

标签:

  壳对于有过pc端加解密经验的同学来说并不陌生,android世界中的壳也是相同的存在(为什么要有壳这里就不描述咯)。看下图(exe = dex):

     技术分享

  概念清楚罗,我们就说下:壳最本质的功能就是实现加载器。你看加壳后,系统是先执行壳代码的。但我们想要的是执行原dex,可是系统此时是不会自动来执行的需要壳去将原dex加载到系统中。ok,壳就说到这里,看android apk壳:

  Android APK加壳技术方案【1】

  Android APK加壳技术方案【2】

  APK加壳【1】初步方案实现详解

  在看完上述的几篇文章后,相信对apk 壳应该有一定的了解(其实apk壳和pc端的都差不多,只是在处理不同的文件格式:dex和exe中会有差别;导致不同的加壳、解壳步骤。当然我们需要了解文件的格式,才能有的放矢哦)。来看下android apk加壳中处理方法:

  1 :编写解壳apk,得到壳的文件:UnShelldex;

  2:编写脚本或代码(你开心就好),对原dex进行encode变成encodeDex,并将其插入(这里有几种姿势哦,看你喜欢咯)到UnShelldex文件中;注意被修改后的UnShelldex必须要符合dex格式,否则android不执行艾(在上述的文章里就对修改后的UnShelldex的checksum、signature 和file_size值进行修正);

  解壳步骤:

  1 执行解壳apk的代码,decode endcodeDex为原来的dex;

  2 模拟android系统把dex装载,让其顺利执行;

  这里需要提及一点:壳绝对不能改变原来代码的执行流程;又不是hook,你改是算什么意思啊!apk壳的思路讲完啦,但这只是纸上谈兵,还有很多细节需要我们考虑。加壳的步骤没什么好考虑的,无非是跟文件格式打交道(当然你要做高精尖的encode是另说啦)。在解壳步骤里,decode也没什么好分析的(主要是跟encode对应,且每个人的处理方式也不一样);把dex装载才是关键,前面说了壳本质就是装载器。上面的文章的思路是在解壳过程中,把decode后的dex直接存在目录,然后调用classloader(这里不太懂,等我看完dalvik源码再来分析)。什么!dex直接放在目录下,别人不是可以直接获取了吗,那加壳干什么啊。是不是觉得加壳然并卵。ok,那我不把dex提取出来放在目录下,直接在内存里装载:

  Android4.0内存Dex数据动态加载技术

  APK加壳【2】内存加载dex实现详解

 

 

资料:

  1 Android APK加壳技术方案【1】

  2 Android APK加壳技术方案【2】

  3 APK加壳【1】初步方案实现详解

  4 Android4.0内存Dex数据动态加载技术

  5 APK加壳【2】内存加载dex实现详解

 

android apk壳

标签:

原文地址:http://www.cnblogs.com/vendanner/p/4813772.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!