本人开发的一个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

 

那么继续判断安装包中的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 下面。 注册* 每段代码都别少...

 

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

 

查看原文