多个应用推荐使用不同签名,除非一些特殊应用场景
最近两个应用同时上线,微信分享上遇到了问题
使用了umeng分享
———-问题
现在的问题是
两个应用(签名keyOne.jks为同一文件)
应用A(包名com.test.A)+ 签名(keyOne.jks)—>打包
应用B (包名com.test.B) +签名(keyOne.jks)—>打包
应用A分享微信成功了、应用B微信分享不成功、
测试应用B在使用与A不同签名的情况下可以分享成功
想知道:
是一定要使用不同签名呢,还是,在设置上有什么问题
———-答案
给到的答案是:
应用A(包名com.test.A)+ 签名(keyOne.jks)—>打包
应用B (包名com.test.B) +签名(keyOne.jks)—>打包
这个情况下 就是 需要不同的应用ab 有不同的签名了 不能通用
他们的包名不一样 你在打包的时候他们的签名也是不一样的 那你都用一个 就会有一个因为 签名不和他自己实际的包名匹配 就造成分享不出去的情况了
———-结论
回头又想了一想签名的用意不就是为了区分嘛
但是也有应用场景需要使用相同的签名
网上找的:android 应用签名的作用
1.、应用程序升级:如果你希望用户无缝升级到新的版本,那么你必须用同一个证书进
行签名。这是由于只有以同一个证书签名,系统才会允许安装升级的应用程序。
如果你采用了不同的证书,那么系统会要求你的应用程序采用不同的包名称,在这种情
况下相当于安装了一个全新的应用程序。如果想升级应用程序,签名证书要相同,包名称要相同!
2.、应用程序模块化:Android 系统可以允许同一个证书签名的多个应用程序在一个进
程里运行,系统实际把他们作为一个单个的应用程序,此时就可以把我们的应用程序以模块
的方式进行部署,而用户可以独立的升级其中的一个模块
3.、代码或者数据共享:Android 提供了基于签名的权限机制,那么一个应用程序就可
以为另一个以相同证书签名的应用程序公开自己的功能。以同一个证书对多个应用程序进行
签名,利用基于签名的权限检查,你就可以在应用程序间以安全的方式共享代码和数据了。
4.不同的应用程序之间,想共享数据,或者共享代码,那么要让他们运行在同一个进程
中,而且要让他们用相同的证书签名
</article>
网友评论