关于android开发的签名和打包问题

如题,什么是签名,签名的作用是什么?

        如果你是一个android开发人员,你们公司有某个模块更新了,你被公司要求为这个模块的更新打一个新版本包。现在问题来了,你不知道打包的签名,然后公司就你一个android开发人员,重要的是如果你不知道什么是签名的话,你直接按照网络上的步骤打包然后发给公司的测试人员。他们就会发现一个问题,当下载新版本后,安装时一直提示安装包的签名不一致导致失败,这种情况你该怎么办?

        其实你不用紧张,你只需要去问公司的技术总监或者相关人员要一个.jks的文件,这个文件就是签名证书。android开发的每个应用都需要我们用一个证书对其进行数字签名,不然的话是无法安装到android手机上的,我们平时在手机上调试应用的时候,是AS自动使用默认的密钥和证书来进行签名的。如果我们实际发布编译时,AS的默认签名就不起作用可,这个时候就需要我们自己手动进行签名了!所以签名的好处有那些,就很清楚了。

        

  • 1.应用程序升级:如果你希望用户无缝升级到新的版本,那么你必须用同一个证书进行签名。这是由于只有以同一个证书签名,系统才会允许安装升级的应用程序。如果你采用了不同的证书,那么系统会要求你的应用程序采用不同的包名称,在这种情况下相当于安装了一个全新的应用程序。如果想升级应用程序,签名证书要相同,包名称要相同!
  • 2.应用程序模块化: Android系统可以允许同一个证书签名的多个应用程序在一个进程里运行,系统实际把他们作为一个单个的应用程序,此时就可以把我们的应用程序以模块的方式进行部署,而用户可以独立的升级其中的一个模块。
  • 3.代码或者数据共享: Android提供了基于签名的权限机制,那么一个应用程序就可以为另一个以相同证书签名的应用程序公开自己的功能。以同一个证书对多个应用程序进行签名,利用基于签名的权限检查,你就可以在应用程序间以安全的方式共享代码和数据了。 不同的应用程序之间,想共享数据,或者共享代码,那么要让他们运行在同一个进程中,而且要让他们用相同的证书签名。 ————上述内容摘自:android 为什么需要签名

至于android studio的打包,网上有太多的教程了我就不啰嗦了。

猜你喜欢

转载自blog.csdn.net/weixin_40600325/article/details/79667997