如何手动给APK文件签名

如何手动给APK文件签名,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

由于您的应用签名密钥用于验证您作为开发者的身份,并确保为您的用户进行无缝而安全的更新,因此,管理和保护您的密钥对于您和您的用户而言都非常重要。 您可以选择使用 Google Play 的 App Signing 以利用 Google 的基础架构安全地管理和存储您的应用签名密钥,也可以选择自行管理和保护您的密钥库和应用签名密钥。

Android 要求所有 APK 必须先使用证书进行数字签署,然后才能安装。 此外,您需要先签署您的 Android App Bundle,才能将其上传到 Play 管理中心。

如何手动给APK文件签名
 
在这里插入图片描述

 

背景

在安装的时候提示没有权限安装,需要签名才能安装。

 

方法

  1. 先生成key store文件。

# 别名是androidtest
# 加密方式RAS
# 有效期 365天
keytool -genkey -v -keystore android.keystore -alias androidtest -keyalg RSA -validity 365

 

回显,里面的内容按照提示随便填写即可。但是密码可以要记住。

Enter keystore password:  
What is your first and last name?
  [Unknown]:  test
What is the name of your organizational unit?
  [Unknown]:  test
What is the name of your organization?
  [Unknown]:  test
What is the name of your City or Locality?
  [Unknown]:  test
What is the name of your State or Province?
  [Unknown]:  test
What is the two-letter country code for this unit?
  [Unknown]:  test
Is CN=test, OU=test, O=test, L=test, ST=test, C=test correct?
  [no]:  yes   

Generating 2,048 bit RSA key pair and self-signed certificate (SHA256withRSA) with a validity of 365 days
    for: CN=test, OU=test, O=test, L=test, ST=test, C=test
Enter key password for <androidtest>
    (RETURN if same as keystore password):  
Re-enter new password: 
[Storing android.keystore]

 

  1. 签名就生成好了证书,第二步就执行签名。

# 对于一般的apk,签名方式就是releasekey。
jarsigner -verbose -keystore androidtest.jks -storepass android -keypass android  apkname.apk releasekey

# 如果是apk需要系统权限的话的, 需要签名为platform key
jarsigner -verbose -keystore androidtest.jks -storepass android -keypass android  apkname.apk platform

 
 

异常处理

如果签名的时候遇到问题如下

 unable to sign jar invalid entry compressed size(......)

 

可以直接用以下命令,删除META-INF的内容。

zip -d your-file.apk META-INF//*

 
 

关于如何手动给APK文件签名问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

原创文章,作者:745907710,如若转载,请注明出处:https://blog.ytso.com/230599.html

(0)
上一篇 2022年1月15日
下一篇 2022年1月15日

相关推荐

发表回复

登录后才能评论