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了。
热门推荐
如何控制自己的潜意识和幻想
2024年女宝宝起名指南:五行缺土的名字选择技巧, 诠释传统与现代的结合
音响功率与音质之间的微妙关系
青椒肉丝的腌制方法及健康功效
常规赛MVP含金量揭秘:从超级巨星到市场价值的影响
用不对称演绎内在平衡的东方美
“奶豆添营养”——奶豆制品你吃够了吗?2024全民营养周
脑卒中检查:CT与CTA的科学选择
火箭燃料竟然要手动雕刻?火药雕刻师那么重要,为何美国不需要?
丙烯颜料的使用技巧
小孩鼻塞流鼻涕怎么办?三种常见原因及家庭护理指南
尼古丁替代疗法在戒烟中的应用与效果分析
鸡蛋壳能不能吃,有营养吗?鸡蛋壳健康新宠,营养超乎想象!
犀牛角真的能治病?科学揭秘:它的成分竟和指甲一样!
王者荣耀周瑜最强出装攻略:暴力输出流、消耗回血流、站桩输出流全解析
植物园里有什么植物 逛三园植物园100种
利咽化痰时令菜——茼蒿
急性肠胃炎知多少
汽车轮胎周边的零件都有什么?
2024年度成语评选活动在河北邯郸揭晓
激光切割常见问题及解决方案:从表面粗糙到切不透
中国独立研制军用手枪的艰辛历程,从51式到84式!
技术为本,科研为魂,浙江省人民医院迈向医学新高峰
浙江四大医院出炉!浙大附一暂时第二,邵逸夫第三,均排全国前60
工厂批次号如何管理
业主投票怎样有效?物业管理中的关键问题解析
固定资产清理收入是什么
霍尔传感器的发展历史与技术革新
网络追剧安全指南:四大注意事项助你远离风险
工伤保险怎样参保