"安卓4.0~4.4加固原理与实现详解"

需积分: 0 0 下载量 137 浏览量 更新于2023-12-19 收藏 675KB PDF 举报
Android加固是一种应用程序保护技术,旨在提高应用程序的安全性和防止恶意攻击。在进行Android加固之前,需要对壳线程的applicationObject进行获取,并建立一个包含所有应用程序的集合。而加固的首代壳(落地)适用于Android 4.0~4.4版本,实现原理是通过对源apk进行加密,然后将加密后的源apk放入壳apk的classes.dex末端,并修改壳的classes.dex的checksum、signature和file_size,以此达到保护应用程序的目的。 加壳的实现角色包括源apk、壳Apk和加壳程序。源apk是被保护的应用程序,壳Apk则是获取加密后的源apk,解密后使用DexclassLoader动态加载。而加壳程序则负责为源apk加密,并将其放入壳中的classes.dex中。具体的结构为,加壳程序首先对源apk进行加密,然后将加密后的apk放入壳apk的classes.dex末端,并修改壳的classes.dex的checksum、signature和file_size。而壳apk会读取自己的classes.dex末尾的加密数据,解密获得源apk,并进行动态加载。 源apk的内容可以根据具体需求进行自定义,只需设置一个Application类即可。而加密程序则主要涉及对源apk的读取加密和放入壳的classes.dex中,以及对dex中的固定位置的check num、file_sizes和signature进行修改。壳apk则需要读取加密数据,解密获得apk,并进行动态加载,这部分主要涉及Java文件操作和类加载器的使用。 总的来说,Android加壳技术是一项非常重要的应用程序保护技术,通过对源apk进行加密、放入壳apk、以及动态加载等方式,提高了应用程序的安全性和防护能力,可以有效防止恶意攻击对应用程序的危害。随着技术的不断发展,相信加壳技术会在未来得到更加广泛的应用和发展。