实践是知识的母亲,知识是生活的明灯。这篇文章主要讲述android app使用微信登录接口回调没有被执行的问题研究相关的知识,希望能为你提供帮助。
本人开发的一个app使用了sharesdk集成微信登录功能,在测试的过程中微信授权登录界面有调用,但是授权后原应用的回调没有被执行
应用的包名是com.kimi.searcher
首先,确认微信点击授权后有没有执行回调,方法是通过日志过滤activitymanager,
日志中有出现
04-16 13:27:43.345 1805-3279/? I/ActivityManager: START u0 {flg=0x18000000 cmp=com.kimi.searcher/.wxapi.WXEntryActivity (has extras)} from uid 10156 on display 0
说明微信有回调app的wxentryactivity
【android app使用微信登录接口回调没有被执行的问题研究】
那么继续判断安装包中的WXEntryActivity是否存在
使用https://github.com/iBotPeaches/Apktool 来反编译apk安装包,发现安装包中不存在com.kimi.searcher.wxapi.WXEntryActivity.取而代之的是com.qq.rnsharesdk.wxapi.WXEntryActivity.
原因分析:com.qq.rnsharesdk.wxapi.WXEntryActivity是放在一个依赖项目中的微信入口activity.被依赖的项目的package是com.qq.rnsharesdk。 activity的名称是.wxapi.WXEntryActivity。
原来gradle 在编程的过程中,androidmanifest.xml中的相对路径组件会根据被依赖包中的package名来生成全路径名称,而不是app项目中的package来生成全路径名称。
于是我在app项目中添加一条activity, 并且把build.gradle中的applicationId改成了com.kimi.searcher。编译后发现回调依然没有被执行,把新包进行反编译,发现androidmanifest.xml中多了一条com.awesomeproject.wxapi.WXEntryActivity。
原因是androidmanfiest.xml的相对路径填充不会使用build.gradle中使用的applicationId,而会使用androidmanifest.xml中的package来进行路径填充。
与往常使用gradlew编译安卓项目,build.gradlew的配置会覆盖androidmanifest.xml的配置的经验不同,androidmanifest.xml的相对路径填充的规则:
1.使用最近的package配置,2.不使用build.gradle中的配置
Android 微信授权登录、获取Wx用户信息,解决无法回调问题微信授权登录,官方说的不是很清楚、所以导致有一部分的坑。
据此记载..(坑)
1.微信注册应用平台的应用签名为 打包keystore的MD5 小写并且去掉 ":" 号组成、或者去下载
微信签名生成工具
输入项目的packageName也可以查看到。
2.授权没反应,监测微信App_Id是否正确、是否按照上1.生成。 当前的App是否正式签名?也就是正式App.. DeBug签名环境的App貌似无法调动微信。
3.关于回调:是否按照官方要求注册WXEntryActivity并且继承Acticiy、
此Activity不能改名,并且在你的 package(项目报名).wxapi.WXEntryActivity.java 下面。 注册* 每段代码都别少...
< !--注册微信回调 WXEntryActivity --> < activity android:name=".wxapi.WXEntryActivity" android:exported="true" android:label="@string/app_name" android:launchMode="singleTop" android:theme="@android:style/Theme.Translucent" />
4.回调方法onResp() 方法没有触发回调、请监测WXEntryActivity onCreate中是否调用此方法 mApi.handleIntent(this.getIntent(), this);
public class WXEntryActivity extends Activity implements IWXAPIEventHandler {private final String TAG = this.getClass().getSimpleName(); public static final String APP_ID = "请自己填写"; public static final String APP_SECRET = "请自己填写"; private IWXAPI mApi; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); mApi = WXAPIFactory.createWXAPI(this, APP_ID, true); mApi.handleIntent(this.getIntent(), this); }//微信发送的请求将回调到onReq方法 @Override public void onReq(BaseReq baseReq) { }//发送到微信请求的响应结果 @Override public void onResp(BaseResp resp) { switch (resp.errCode) { case BaseResp.ErrCode.ERR_OK: //发送成功 break; case BaseResp.ErrCode.ERR_USER_CANCEL: //发送取消 break; case BaseResp.ErrCode.ERR_AUTH_DENIED: //发送被拒绝 break; default: //发送返回 break; } finish(); }}
5.当授权时候进入WXEntryActivity、当前背景可能是黒或白,为了不影响用户体验,可以把当前Activity设置为透明。android:theme="@android:style/Theme.Translucent" ,可以参照上3. WXEntryActivity注册格式。
以上便是授权登录遇到的坑、只怪Wx要求格式的有个性、多多少少会遇到这样的坑。
文章图片
授权登录并且拿取Wx用户信息,简单三部曲:
* * 1.sendReq(req). 用户授权可以拿到 code * * 2.用code.调用Wx接口拿到 openid & accessToken * * 3.通过openid & accessToken 俩参数可以拿到最终用户信息 * *
具体可参考:微信授权登录取用户信息步骤
部分代码:
/** * 获取openid accessToken值用于后期操作 * * @param code 请求码 */ private void getAccess_token(final String code) { new Thread(new Runnable() { @Override public void run() { String path = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" + APP_ID + "& secret=" + APP_SECRET + "& code=" + code + "& grant_type=authorization_code"; try { JSONObject jsonObject = JsonUtils.initSSLWithHttpClinet(path); // 请求https连接并得到json结果 if (null != jsonObject) { String openid = jsonObject.getString("openid").toString().trim(); String access_token = jsonObject.getString("access_token").toString().trim(); getUserMesg(access_token, openid); }} catch (Exception e) { e.printStackTrace(); } } }).start(); }/** * 获取微信的个人信息 * * @param access_token * @param openid */ private void getUserMesg(final String access_token, final String openid) { String path = "https://api.weixin.qq.com/sns/userinfo?access_token=" + access_token + "& openid=" + openid; try { JSONObject jsonObject = JsonUtils.initSSLWithHttpClinet(path); // 请求https连接并得到json结果 if (null != jsonObject) { String nickname = jsonObject.getString("nickname"); int sex = Integer.parseInt(jsonObject.get("sex").toString()); String headimgurl = jsonObject.getString("headimgurl"); Log.e(TAG, "getUserMesg 拿到了用户Wx基本信息.. nickname:" + nickname); } } catch (Exception e) { e.printStackTrace(); } return; }
具体代码:微信授权登录 - 案例 Dome。
参考、感谢:
1.http://blog.csdn.net/xiong_it/article/details/48317527
2.https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list& t=resource/res_list& verify=1& id=1417751808& token=& lang=zh_CN
推荐阅读
- pandas数组(pandas Series)-apply方法自定义函数
- Computer Networking: A Top Down Approach
- Android之Fragment的优点和作用
- Android Service初解
- MapReduce (基于 FileInputFormat 的 mapper 数量控制)
- android(Android中用文件初始化sqlite数据库)
- android高仿小视频应用锁3种存储库QQ小红点动画仿支付宝图表等源码
- android okhttp和webview session共享
- APP开发外包公司如何选择?