apk 同一个签名

多个应用推荐使用不同签名,除非一些特殊应用场景

最近两个应用同时上线,微信分享上遇到了问题 
使用了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.不同的应用程序之间,想共享数据,或者共享代码,那么要让他们运行在同一个进程 
中,而且要让他们用相同的证书签名
 

发布了74 篇原创文章 · 获赞 36 · 访问量 25万+

猜你喜欢

转载自blog.csdn.net/kdsde/article/details/90404266