android读取应用签名信息

本文介绍了一种通过命令行和应用程序内部方法获取签名指纹的方式。通过命令行输入特定命令并提供密钥库路径及密码,可以查看签名信息。此外,还提供了一个在应用程序中实现的方法,该方法使用了MD5、SHA1或SHA256加密算法来获取签名指纹。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.命令方式

$ keytool -list -v -keystore "keystore文件路径"
输入以上命令,需要输入签名文件口令(密码请联系开发人员)即可查看。

2.本应用内实现方式

调用getCertificateFingerprint方法,type为”MD5”,”SHA1”,”SHA256”。返回值为签名指纹对应类型串。


    /**
     * 
     * @param context
     * @param type
     *            [MD5,SHA1,SHA256]
     * @return
     */
    public static String getCertificateFingerprint(Context context, String type) {
        // 获取包管理器
        PackageManager pm = context.getPackageManager();

        // 在用其他包名的前提是,此方法传递的参数Context应该是对应包的上下文。
        String packageName = context.getPackageName();// 这里也可直接使用指定包名
        // 返回包括在包中的签名信息
        int flags = PackageManager.GET_SIGNATURES;
        PackageInfo packageInfo = null;
        try {
            // 获得包的所有内容信息类
            packageInfo = pm.getPackageInfo(packageName, flags);
        } catch (PackageManager.NameNotFoundException e) {
            e.printStackTrace();
        }
        // 签名信息
        Signature[] signatures = packageInfo.signatures;
        byte[] cert = signatures[0].toByteArray();
        // 将签名转换为字节数组流
        InputStream input = new ByteArrayInputStream(cert);
        // 证书工厂类,这个类实现了出厂合格证算法的功能
        CertificateFactory cf = null;
        try {
            cf = CertificateFactory.getInstance("X509");
        } catch (CertificateException e) {
            e.printStackTrace();
        }
        // X509证书,X.509是一种非常通用的证书格式
        X509Certificate c = null;
        try {
            c = (X509Certificate) cf.generateCertificate(input);
        } catch (CertificateException e) {
            e.printStackTrace();
        }
        String hexString = null;
        try {
            // 加密算法的类,这里的参数可以使MD4,MD5,SHA1等加密算法
            MessageDigest md = MessageDigest.getInstance(type);
            // 获得公钥
            byte[] publicKey = md.digest(c.getEncoded());
            // 字节到十六进制的格式转换
            hexString = byte2HexFormatted(publicKey);
        } catch (NoSuchAlgorithmException e1) {
            e1.printStackTrace();
        } catch (CertificateEncodingException e) {
            e.printStackTrace();
        }
        return hexString;
    }

    /**
     * 将获取到得编码进行16进制转换
     * 
     * @param arr
     * @return
     */
    private static String byte2HexFormatted(byte[] arr) {
        StringBuilder str = new StringBuilder(arr.length * 2);
        for (int i = 0; i < arr.length; i++) {
            String h = Integer.toHexString(arr[i]);
            int l = h.length();
            if (l == 1)
                h = "0" + h;
            if (l > 2)
                h = h.substring(l - 2, l);
            // 这里做了大写转换处理,比较时请转换或者使用IgnoreCase忽略大小写
            str.append(h.toUpperCase());
            if (i < (arr.length - 1))
                str.append(':');
        }
        return str.toString();
    }

其他

\.android\debug.keystore 的密码是 android

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值