查看apk簽名 和 keystore 的信息


原文出處:https://www.jianshu.com/p/90b698002215

 

1、keytool -printcert -file ***(把apk文件下的META-
INF文件夾解壓出來,得到其中的密鑰.RSA文件)

2、keytool -list -v -keystore debug.keystore 查看證書信息

3、給空白包簽名 (注意 alias 值)

jarsigner -verbose -keystore [keystorePath] -signedjar [apkOut] [apkIn] [alias]
jarsigner -verbose -keystore debug.keystore -signedjar test2.apk unsign1.apk test

 

4、在應用代碼中獲取簽名信息

public String getSHA1Signature(Context context) {
try {
PackageInfo info = context.getPackageManager().getPackageInfo
(context.getPackageName(), PackageManager.GET_SIGNATURES);

byte[] cert = info.signatures[0].toByteArray();

MessageDigest md = MessageDigest.getInstance("SHA1");
byte[] publicKey = md.digest(cert);
StringBuilder hexString = new StringBuilder();
for (int i = 0; i < publicKey.length; i++) {
String appendString = Integer.toHexString(0xFF & publicKey[i])
.toUpperCase(Locale.US);
if (appendString.length() == 1)
hexString.append("0");
hexString.append(appendString);
hexString.append(":");
}
return hexString.toString();
} catch (PackageManager.NameNotFoundException e) {
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return null;
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM