android证书指纹的生成

本文介绍了如何使用keytool命令行工具以及Java代码来获取APK的证书信息,特别是证书指纹。证书指纹实际上是证书内容的MD5摘要,可以通过对Signature info进行MD5哈希计算得到。详细步骤和代码参考链接已提供。
摘要由CSDN通过智能技术生成

 apk的证书能用keytool来获取,证书位置为./META-INF/CERT.RSA,提取出来后用keytool -printcert -file CERT.RSA 可以获取关于证书的各种信息


通过java code也能获取到apk的证书,具体方法如下链接

http://blog.csdn.net/wulianghuan/article/details/18400581 


其中一直搞不清楚证书指纹从哪获得,最后才知道很简单,证书指纹就是整个证书的md5,。

获取到 Signature info后,直接对info.toByteArray()做md5处理及为Signature的指纹


String fingerPrint = getFingerPrintFromSignature(info.toByteArray());


 
private static String getFingerPrintFromSignature(byte[] signature) throws NoSuchAlgorithmException {
        MessageDigest md = MessageDigest.getInstance("MD5");
        byte[] signatureMd5Raw = md.digest(signature);
        String signatureMd5 = String.format("%032x", new BigInteger(1, signatureMd5Raw)).toUpperCase();
        Log.d(TAG, "signature md5:" + signatureMd5);
        return signatureMd5;
    }


Qt for Android 生成签名的过程主要是为了让应用程序能够在Android设备上运行并通过Google Play商店分发。以下是基本步骤: 1. **创建Keystore**: 首先,你需要一个私钥对(keystore pair),通常使用Java Keytool工具生成。在命令行中,你可以执行如下命令创建一个新的keystore文件: ``` keytool -genkey -v -keystore myapp.keystore -alias myappkey -storepass password -keyalg RSA -keysize 2048 ``` 这里需要替换`myapp.keystore`, `myappkey` 和 `password`为你想要的文件名、别名和密码。 2. **获取证书指纹**: 获取keystore的证书FingerPrint,这将在签名过程中用到: ``` keytool -list -v -keystore myapp.keystore -alias myappkey ``` 3. **签名Apk**: 使用Qt提供的qmake Android模块配置,并使用`jom` 或 `ninja` 构建目标时,会自动处理签名。如果你手动编译,可以在构建脚本中添加类似这样的行: ```bash qmake YOUR_PROJECT.pro ninja -jN # 或者 make android-release ``` 在配置文件中设置`CONFIG += android-key-store`,并且指定`android-signing-config`路径指向包含keystore信息的`signing.json`文件。 4. **signing.json**: 这是一个JSON文件,定义了如何将keystore信息应用到APK中,包括keystore路径、alias、密码等。例如: ```json { "ks": "/path/to/myapp.keystore", "ks_password": "your_keystore_password", "alias": "myappkey", "store_type": "JKS" } ``` 5. **验证签名**: 完成签名后,你可以检查APK是否已正确签名,可以使用` jarsigner`或Android Studio的签名验证功能进行确认。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值