Android应用签名校验和完整性校验实战
创作时间:
作者:
@小白创作中心
Android应用签名校验和完整性校验实战
引用
CSDN
1.
https://blog.csdn.net/u011195398/article/details/84567580
签名校验和完整性校验是Android应用开发中重要的安全措施,主要用于防范二次打包和盗版风险。本文将详细介绍如何进行签名校验,包括获取APK、获取调试应用的keystore、对APK进行重新签名等步骤,并提供具体的命令行操作示例。
准备工作
在开始之前,你需要确保已经完成以下准备工作:
- 项目代码:确保你有一个完整的Android项目代码。
- 主要实现类:了解项目中的主要实现类,例如
SignatureChecker。
验证默认签名信息
1. 获取应用的APK
在编写好项目以后,通过以下步骤获取APK:
- 点击
build -> build apk。 - 文件路径:
app/build/outputs/apk/debug/app-debug.apk。
2. 获取调试应用的keystore
- 打开Finder程序,路径:
Go -> Home -> ./android/debug.keystore。 - 使用keytool命令查看android模式调试debug.keystore的签名信息,默认密码为空。
命令:
keytool -list -v -keystore debug.keystore
3. 信息对比
检查apk文件中的签名信息:
命令:
keytool -printcert -file CERT.RSA
对比信息:
在这里完全可以看出,我们的apk默认的是经过androidstudio的debug.keystore来签名过的APK。
对APK进行重新签名
创建两个keystore
创建两个KeyStore文件,分别命名为keyStoreA和keyStoreB。
创建一个未签名的Apk,命名为app-release-unsigned。
对APK进行签名
使用KeyStoreA文件对app-release-unsigned进行签名,签名后的APK为app-release-keystoreA。
命令:
jarsigner -verbose -keystore /path/to/keystoreA -signedjar /path/to/app-release-keystoreA.apk /path/to/app-release-unsigned.apk android
命令解析:
-keystore参数指定您的私钥的绝对路径。-signedjar参数指定签名后apk文件存放绝对的路径。[未签名的文件路径]指定要签名apk文件的绝对路径。[您的证书名称]是指您创建密钥时您设置的证书名称。
删除APK的签名信息并重新打包
- 解压
app-release-keystoreA,删除META-INFO文件夹下的三个文件:
ANDROID.RSAANDROID.SFMANIFEST.MF
注意:这里的三个文件的名称因为工具的原因可能会根据改变,我们删除的时候,看他的后缀名称就好。
重新打包删除后的
app-release-keystoreA文件,后缀名改为APK。使用
keyStoreB对app-release-keystoreA进行重新签名,生成app-release-keystoreB。
命令:
jarsigner -verbose -keystore /path/to/keystoreB -signedjar /path/to/app-release-keystoreB.apk /path/to/app-release-keystoreA.apk androidx
防止APP被盗版验证
KeyStoreA和KeyStoreB的签名MD5比较
- 安装keystoreA签名过的APK文件。
命令:
adb install -r /path/to/app-release-keystoreA.apk
生成MD5值:
8ad65c2224d9c303250c7c49a3672323
- 修改签名,使用KeyStoreB重新签名
命令:
adb install -r /path/to/app-release-keystoreA.apk
生成MD5值:
8fe878055ba594ee41ba8a4b2e0ca3e5
注意:这里的MD5值不和KeyStore显示的格式一样,是因为我格式再次进行了MD5加密。
可以看出来,即使是同样的APK,但是使用不同的签名还是会出现不同的APK值。所以,我们可以在应用中做校验,当MD5值不一样时,就不是官方正版的APK了。
热门推荐
奥迪A4L左梁如何修复?详解损伤程度与维修方案
鬼谷子的智慧:人性的洞察
鬼谷子的核心思想是什么
nfo文件是什么
6类证书助力提升退休养老金,快来看看你符合条件吗?
首创!北大团队发现全新作用机制的抗病天然产物
林超民闲话普洱茶:从历史到现代的茶文化解读
这三个养心要穴,触手可及
互动道路交通安全教育基地设计,多媒体交通教育展厅AI互动设备
我去合肥吃了臭鳜鱼,才终于明白:为啥臭鳜鱼很难走出安徽?
壶腹癌的治疗方法有哪些
角磨机安全操作规程 安全操作指南!
什么是A股和B股?两者有何关联和区别?
企业所得税代扣代缴操作流程与注意事项
个体户营业执照材料准备与法律要求
关节炎怎么治疗能彻底除根
AI在绩效管理中的应用:智能化员工评估与发展
5G NR的物理资源详解:频域与时域资源的组织方式
领导逼你主动离职,怎么办?
近视眼准分子激光治疗的结果如何?适合哪些人群进行此项手术?
激光眼睛治疗的原理是什么?它的结果和靠谱性如何?
农村最简单的租地合同:法律条款与注意事项
Document Title
半年打一次的降脂针,和他汀有什么区别?应该怎么选?
肠易激综合征:别让焦虑影响你的肠胃健康,快乐心态助你轻松应对
肠易激综合征胃胀气怎么缓解
原来,吃辣也能是一种养生
如何开展团结协作的活动
腰椎骨折恢复锻炼方法是什么
项目管理信息通知怎么写