com.hadoopz.MyDroidLib.util.SignatureUtils Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2019 jw362j.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.hadoopz.MyDroidLib.util;
import android.content.Context;
import android.content.pm.PackageManager;
import java.io.ByteArrayInputStream;
import java.security.MessageDigest;
import java.security.cert.CertificateFactory;
import java.security.cert.X509Certificate;
import javax.security.auth.x500.X500Principal;
import android.content.pm.Signature;
/**
*
* @author jw362j
*/
public class SignatureUtils {
// 如需要小写则把ABCDEF改成小写
private static final char HEX_DIGITS[] = {'0', '1', '2', '3', '4', '5',
'6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};
/**
* 检测应用程序是否是用"CN=Android Debug,O=Android,C=US"的debug信息来签名的
* 判断签名是debug签名还是release签名
*/
private final static X500Principal DEBUG_DN = new X500Principal(
"CN=Android Debug,O=Android,C=US");
/**
* 进行转换
*/
public static String toHexString(byte[] bData) {
StringBuilder sb = new StringBuilder(bData.length * 2);
for (int i = 0; i < bData.length; i++) {
sb.append(HEX_DIGITS[(bData[i] & 0xf0) >>> 4]);
sb.append(HEX_DIGITS[bData[i] & 0x0f]);
}
return sb.toString();
}
/**
* 返回MD5
*/
public static String signatureMD5(Context context) {
Signature[] signatures = getSignatures(context);
try {
MessageDigest digest = MessageDigest.getInstance("MD5");
if (signatures != null) {
for (Signature s : signatures) {
digest.update(s.toByteArray());
}
}
return toHexString(digest.digest());
} catch (Exception e) {
return "";
}
}
/**
* SHA1
*/
public static String signatureSHA1(Context context) {
Signature[] signatures = getSignatures(context);
try {
MessageDigest digest = MessageDigest.getInstance("SHA-1");
if (signatures != null) {
for (Signature s : signatures) {
digest.update(s.toByteArray());
}
}
return toHexString(digest.digest());
} catch (Exception e) {
return "";
}
}
/**
* SHA256
*/
public static String signatureSHA256(Context context) {
Signature[] signatures = getSignatures(context);
try {
MessageDigest digest = MessageDigest.getInstance("SHA-256");
if (signatures != null) {
for (Signature s : signatures) {
digest.update(s.toByteArray());
}
}
return toHexString(digest.digest());
} catch (Exception e) {
return "";
}
}
/**
* 判断签名是debug签名还是release签名
*
* @return true = 开发(debug.keystore),false = 上线发布(非.android默认debug.keystore)
*/
public static boolean isDebuggable(Context context) {
Signature[] signatures = getSignatures(context);
// 判断是否默认key(默认是)
boolean debuggable = true;
try {
for (int i = 0, c = signatures.length; i < c; i++) {
CertificateFactory cf = CertificateFactory.getInstance("X.509");
ByteArrayInputStream stream = new ByteArrayInputStream(signatures[i].toByteArray());
X509Certificate cert = (X509Certificate) cf.generateCertificate(stream);
debuggable = cert.getSubjectX500Principal().equals(DEBUG_DN);
if (debuggable) {
break;
}
}
} catch (Exception e) {
}
return debuggable;
}
public static String signatureName(Context context) {
Signature[] signatures = getSignatures(context);
try {
for (int i = 0, c = signatures.length; i < c; i++) {
CertificateFactory cf = CertificateFactory.getInstance("X.509");
ByteArrayInputStream stream = new ByteArrayInputStream(signatures[i].toByteArray());
X509Certificate cert = (X509Certificate) cf.generateCertificate(stream);
String pubKey = cert.getPublicKey().toString(); //公钥
String signNumber = cert.getSerialNumber().toString();
System.out.println("signName:" + cert.getSigAlgName());//算法名
System.out.println("pubKey:" + pubKey);
System.out.println("signNumber:" + signNumber);//证书序列编号
System.out.println("subjectDN:" + cert.getSubjectDN().toString());
System.out.println(cert.getNotAfter() + "--" + cert.getNotBefore());
}
} catch (Exception e) {
}
return "";
}
public static Signature[] getSignatures(Context context) {
if (context == null) {
return null;
}
try {
return context.getPackageManager().getPackageInfo(context.getPackageName(), PackageManager.GET_SIGNATURES).signatures;
} catch (PackageManager.NameNotFoundException ex) {
return null;
}
}
}