你的位置:首页 > 操作系统

[操作系统]Android在代码中获取应用签名

平时都是用AS敲命令获取签名信息。。。还没有在代码中获取过签名~

也算是老编程了,没做过这个稍微有点尴尬。。。本着有好轮子就用的原则,网上找了几篇博客,这块内容已经很完善了,我也没什么可以优化的。。。

主要参(zhao)考(chao) >public class AppInfoUtils { public final static String SHA1 = "SHA1"; /** * 返回一个签名的对应类型的字符串 * * @param context * @param packageName * @param type * * @return */ public static String getSingInfo(Context context, String packageName, String type) { String tmp = null; Signature[] signs = getSignatures(context, packageName); for (Signature sig : signs) { if (SHA1.equals(type)) { tmp = getSignatureString(sig, SHA1); break; } } return tmp; } /** * 返回对应包的签名信息 * * @param context * @param packageName * * @return */ public static Signature[] getSignatures(Context context, String packageName) { PackageInfo packageInfo = null; try { packageInfo = context.getPackageManager().getPackageInfo(packageName, PackageManager.GET_SIGNATURES); return packageInfo.signatures; } catch (PackageManager.NameNotFoundException e) { e.printStackTrace(); } return null; } /** * 获取相应的类型的字符串(把签名的byte[]信息转换成16进制) * * @param sig * @param type * * @return */ public static String getSignatureString(Signature sig, String type) { byte[] hexBytes = sig.toByteArray(); String fingerprint = "error!"; try { MessageDigest digest = MessageDigest.getInstance(type); if (digest != null) { byte[] digestBytes = digest.digest(hexBytes); StringBuilder sb = new StringBuilder(); for (byte digestByte : digestBytes) { sb.append((Integer.toHexString((digestByte & 0xFF) | 0x100)).substring(1, 3)); } fingerprint = sb.toString(); } } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } return fingerprint; }}

  在代码中调用(获取SHA1值):

String signal = AppInfoUtils.getSingInfo(getApplicationContext(), getPackageName(), AppInfoUtils.SHA1);

  同理,我们也可以获取MD5和SHA256的值。

不习惯直接转载,喜欢自己撸一下,不过文中肯定会附上原作的id的~