本文预计阅读时间为5分钟
着急的同学可以直接翻看后面的解决方法,不着急的同学可以看看解决过程思路。
问题:
微信SDK分享和登录时,发现分享或者登录成功后无法接收回调。
思考解决思路:
第一时间排查签名与包名,AndroidManifest.xml配置,由于是登录和分享都是成功的状态,所以签名和AndroidManifest.xml配置这两个地方应该没问题。然后我又想起来微信曾经在某个版本突然把回调去掉了的这个事,接下来我去官网下载了官方sample,在里面修改了appId和build.gradle中的applicationId,运行发现官方sample也接收不到回调了。
在微信群里请教了微信安卓负责人@赵原哥,赵原哥很热心,给我拉了个小群,叫了几个人来讨论。讨论中1.他们说有没有什么exception信息,我这边没有看到;2.他们说得点击分享完成后微信对话框里的回到应用,才能触发回调,我是点了的,所以没问题。3.他们说网易新闻分享能成功回调,让我下一个在我的手机测试下,我下了,确实是可以。讨论陷入沉默。估计没有现场,确实不好解决。但他们已经尽力了。在这里表示万分感谢。
第二天,我决定用官方的keystore,一码不改地来运行sample。这次官方sample可以成功运行了。我脑子一下清醒起来。对照了下工程,发现我的工程有个不一样的地方,那就是工程源码的packageName跟build.gradle的applicationId不一样。举个例子:我的packageName是com.a.b,我的application是com.b.c,现在我的WXEntryActivity放在了com.a.b.wxapi包里。嗯,感觉问题就是这里了。于是我把WXEntryActivity放到com.b.c.wxapi,运行工程,果不其然,回调Log打出来了。呼。。。
这时脑子里充满困惑,packageName和applicationId的不同地方在哪里。谷歌一下,马上知道。得到如下内容:
1.application id 负责 App 的进程 ID
2.package name 负责 R的包名以及 Manifest 中 Activity 等四大组件的相对包名
3.当没有设置applicationId时,那么applicationId=packageName
原来如此。这么看来,微信应该是根据App进程ID来调用应用的WXEntryActivity。
下面我把解决方法再强调一次:
解决方法:
WXEntryActivity.java必须得放在应用applicationId(不是packageName)路径下的wxapi目录中。
那些让你痛苦的bug,最终都会让你更强大!----致所有的奋斗在一线的程序员