Android在代码中获取应用签名

时间:2022-11-19 12:40:23

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

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

主要参(zhao)考(chao)了http://blog.csdn.net/hcwfc/article/details/41560591这篇博客,下面贴上代码:

获取签名封装类:

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的~