Android PackageManager 为同一个 apk 返回不同的签名

问题描述

我有一个 Android 应用程序,我想在运行时验证它的签名。这是我的代码:

    @SuppressLint("PackageManagerGetSignatures")
    private boolean validSignature(Context context) {
        try {
            PackageInfo info = context.getPackageManager()
                    .getPackageInfo(context.getPackageName(),PackageManager.GET_SIGNATURES);
            for (Signature signature : info.signatures) {
                MessageDigest md = MessageDigest.getInstance("SHA");
                md.update(signature.toByteArray());
                final String currentSignature = Base64.encodeToString(md.digest(),Base64.DEFAULT).trim();
                for (String validSig : validSignatureList)
                    if (validSig.equals(currentSignature))
                        return true;
            }
        } catch (Throwable ignored) {
        }
        return false;
    }

对于相同的 APK,在某些设备上会验证 APK,而在某些设备上则不会。当我调试代码时,signature.toByteArray() 在不同设备上有不同的值。我错过了什么,我可以做些什么来解决它?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...