所有的android应用程序都要求开发人员用一个证书进行数字签名,Android系统不会安装没有进行数字签名的应用程序。
平时我们开发的程序可以安装在模拟器上并运行,是因为在应用程序开发期间,由于是以debug模式进行编译的,因此开发工具会自动安装默认的密钥和证书来进行签名,而于发布模式编译时,就不会得到自动签名,这样就需要进行手工签名。
签名的好处
应用系统升级:如果你希望用户无缝升级到新的版本,那么你必须用同一个证书进行签名。这是由于只有以同一个证书签名,系统才会允许安装升级的应用程序。如果你采用了不同的证书,那么系统会要求你的应用程序采用不同的包名称,在这种情况下相当于安装了一个全新的应用。如果想升级应用程序,证书签名要相同,包名程也要相同。应用程序模块化:Android系统可以允许同一个证书签名的多个应用程序在同一个进程里运行,系统实际把他们作为一个单个的应用程序,此时就可以把我们的应用程序以模块的方式进行部署,而用户可以独立的升级其中的一个模块。代码或者数据共享:Android系统提供了基于签名的权限机制,那么一个应用程序就可以为另一个以相同证书签名的应用程序公开自己的功能,以同一个证书对多个应用程序进行签名,利用基于签名的权限检查,你就可以在应用程序间以安全的方式共享代码和数据了。
不同的应用程序之间,想共享数据,或者共享代码,那么要让他们运行在同一个进程中,而且要让他们用相同的证书签名。
转载请注明原文地址: https://ju.6miu.com/read-1202672.html