android - 不同类型的APK

标签 android apk

谁能解释一下它们之间的区别:

  • 签名apk
  • 未签名的 apk
  • Debug模式下的apk
  • apk 处于 Release模式

虽然很明显,签名的apk是你用自己的证书生​​成的apk,而未签名的是没有证书的。

特别是debug模式下的apk和release模式下的apk到底是什么意思?

这两个与签名apk和未签名apk有什么关系?

<我> 已编辑:除此之外还有其他类型的 apk 吗?

我已经阅读了文档 http://developer.android.com/tools/publishing/app-signing.html

它只解释了Signing in Debug ModeSigning in Release Mode,但是他们没有提到 Debug模式下的apk和 Release模式下的apk .

最佳答案

与您可以使用数字 key 对文档进行签名以证明其来源和所有权以及网站拥有相应证书的方式相同,您可以通过使用 SDK 提供的工具对 APK 进行签名来对它们执行相同的操作。

未签名与签名 APK:

一个已经签名,另一个还没有。就这样。想想 GPGed 电子邮件或网站,在地址栏上带有绿色东西的签名 APK 和普通电子邮件或没有 ssl 的网站,用于未签名的 APK。

在讲debug模式和release模式之前,我先简单介绍一下签名,其实就是说权威认证的签名和自签名。

当您访问受 SSL 保护的网站时,您可能会看到一条警告消息或 URL 旁边的红色 X,具体取决于浏览器,警告您该证书不可信任。通常这意味着该网站正在使用自签名证书。这意味着您无法真正分辨出证书是谁制作的,也没有人能真正说它是真实安全的,或者它来自它所说的地方。

另一方面,权威机构认证的签名证书,他们有某个人(一家公司)是已知的并且(应该)保证证书的质量并且谁在使用它应该是谁。

现在回到 APK:

当您只是测试您的应用程序时,当您想要测试它时,您实际上并不需要适当的证书,因为您是在您的设备上安装该应用程序的人并且您知道(至少您应该)该应用程序你所做的应该不会引起任何问题。

另一方面,当您将它们转换到 Android 市场时,重要的是要知道人们正在下载的应用确实是您的应用,因此您需要使用正确签名的证书。一个你不能失去的,等等等等。

这将我们带到 Debug模式和 Release模式。

它们只是构建/部署环境/设置以帮助您提高工作效率。

当您选择 Debug模式时,apk 将(可能?)包含更多的调试信息(并且更大)并且通常会使用您的自签名证书(调试 key )进行签名(通常情况下) ) 自动生成。

当您选择 Release模式时,它(应该)去除无用的调试信息以减小您应用的大小,并使用在市场上发布应用所必需的认证 key 正确签署您的 APK。

希望这对您有所帮助,如果您需要更多说明,请在评论中提问

关于android - 不同类型的APK,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28668248/

相关文章:

android - 是否有处理 Android XML 的 emacs 模式?

android - 如何通过 Bluestacks 在 Mac 上运行 apk 文件

java - 找出android中的http响应代码

Android 小部件按钮停止工作

java - android,检查 url 是否可以下载东西

android - 如何确定哪个 android 市场用于下载我的应用程序

java -> 无法初始化类 com.android.repository.api.RepoManager

java - 将 EditText 保存在 bundle 中并在布局更改时恢复它

android - 使用已安装的文件编辑器(如果有)编辑纯文本文件的 Intent

Android INSTALL_FAILED_INVALID_URI