解析APK中CERT.RSA文件,获取公钥证书

1.apk解压后的目录结构

首先我们找一个已经签名的apk文件,修改后缀名为zip,然后解压。可以看到里面有一个META-INF文件夹,里面就是签名验证的文件。有三个文件MANIFEST.MF、CERT.SF、CERT.RSA分别保存着不同的签名信息

CERT.RSA:存放着公钥证书

2.查看公钥证书

将CERT.RSA 后缀名修改为p7b, 然后双击CERT.p7b---》点击逻辑存储名---》点击证书---》双击颁发给--》详细信息---》公钥  即可得到公钥信息(此处显示的是16进制)

3.获取预置到设备里的公钥证书,比如 LZ.cer (PEM格式) 数据以Base64表示

4.解析CERT.RSA文件的公钥

  1. 在C:\Program Files\Java\jre1.8.0_201\lib目录下找到rt.java包,放进项目libs下

  2.在dependencies下加入  compileOnly files('libs/rt.jar')

  3.获取公钥

5.如果是高版本,比如Android10,需要在第3步的前面增加反射方法,才能使用

 

6.比较证书。比较签名文件 CERT.RSA里的公钥证书和预置到设备里的公钥证书 LZ.cer(PEM格式)是否相等。

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值