客户端安全(加固)

本文详细介绍了安卓应用加固的过程,包括代码加密、解密过程以及衍生的功能,如SO加密、防调试等。加固的初衷是保护代码不被剽窃,通过加密DEX文件,再结合自定义的壳程序进行动态加载,以提高应用的安全性。然而,加固并不能100%防住破解,只能增加破解的难度。
摘要由CSDN通过智能技术生成

上一篇签名说到,签名只是确保应用在传递过程不被篡改,这是一致性原则。但是,可以被剽窃啊,所以还需要一层防护:加密!这就是加固的初衷。

安卓的混淆,某种意义上讲也是一种“加密”,所以在生产包上尽量要启用混淆。但是混淆毕竟不是真正意义的加密(即别人完全无法破解),混淆只是一种乱编码而已,花点时间仍然可以把逻辑破解出来,所以需要真正的加密。

一、保护对象

那么加密对象是谁?跟签名那样是整个应用包加密吗?当然不能,因为加密后要解密啊,整个应用包都加密了,谁来解密?操作系统吗?操作系统没有你的解密逻辑和密钥,如何解密?这点跟签名不同,签名可以由操作系统来校验,是因为签名算法公开、密钥也可以公开(公钥),操作系统能有足够信息进行签名校验。如果加密也要做到如此,除非操作系统自己搞一套,而且要跟每个应用相关(不能大统一),这还是有难度的,所以安卓应用只提供签名机制,未提供加密机制(混淆算半加密,但是混淆规则是应用告诉操作系统的,不是操作系统自己的规则)。

所以,不能对整个应用进行加密。那对谁加密呢?加密的目的是什么?是为了防止剽窃代码,也就是说,我们对代码进行加密就可以了。在应用包内(内容见截图),代码对应的是dex文件,所以,加密的对象就是dex文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值