当前位置:  开发笔记 > 前端 > 正文

使用Android开发接入第三方原生SDK实现微信登录

这篇文章主要介绍了使用Android开发接入第三方原生SDK实现微信登录,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

微信开放平台 : https://open.weixin.qq.com/

一、准备工作 :

1. Android Studio环境下:在build.gradle文件中,添加如下依赖即可:

dependencies {
 implementation'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+'
}

2. 在清单文件AndroidManifest.xml中加入权限:


 

 

 

 

二、接入 :

1. 注册微信:

想要使我们的程序启动之后,微信终端可以响应我们我们的程序的话.就必须在代码中像微信终端注册我们的id

(可以在程序的入口Activity的OnCreat中注册,也可以在MyApplication中,或者是在其他合适的地方将我们的应用id注册到微信),此处在Application中:

// 1.声明一个statid的IWXAPI 以及APPID
private static IWXAPI mWxApi;
private String WX_APPID = "";
 
// 2.初始化微信SDK
mWxApi = WXAPIFactory.createWXAPI(this, WX_APPID, true);
mWxApi.registerApp(WX_APPID);

2. 发起登录

if (BaseApplication.mWxApi!= null && BaseApplication.mWxApi.isWXAppInstalled()) {
 final SendAuth.Req req = new SendAuth.Req();
 req.scope = "snsapi_userinfo";
 req.state = "wechat_sdk_fth";
 BaseApplication.mWxApi.sendReq(req);
 } else {
 Toast.makeText(LoginActivity.this, "您还没有安装微信", Toast.LENGTH_SHORT).show();
 }

3. 新建一个包 包名为wxapi,新建一个类名为WXEntryActivity的类,这个类名和包名是微信规定的,木有办法,必须一致了

然后在清单文件AndroidManifest.xml中声明该类:




4. WxEntryActivity类代码如下:

public class WXEntryActivity extends Activity implements IWXAPIEventHandler {
 
 private Bundle bundle;
 
 @Override
 protected void onCreate(Bundle savedInstanceState) {
 super.onCreate(savedInstanceState);
 BaseApplication. mIwapi.handleIntent(getIntent(), WXEntryActivity.this); //必须调用此句话
 }
 
 @Override
 protected void onNewIntent(Intent intent) {
 super.onNewIntent(intent);
 BaseApplication. mIwapi.handleIntent(intent, WXEntryActivity.this);//必须调用此句话
 }
 
 @Override
 public void onReq(BaseReq req) {
 System. out.println();
 }
 
 /**
 * API:https://open.weixin.qq.com/ cgi- bin/showdocument ?action=dir_list&t=resource/res_list&verify=1&id=open1419317853 &lang=zh_CN
 * 在此处得到Code之后调用https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code 获取到token和openID。
 * 之后再调用https://api.weixin.qq.com/sns/userinfo?access_token=ACCESS_TOKEN&openid=OPENID 获取用户个人信息
 */
 @Override
 public void onResp(BaseResp arg0) {
 bundle=getIntent().getExtras();
 SendAuth.Resp resp = new SendAuth.Resp( bundle);
 //获取到code之后,需要调用接口获取到access_token
 if (resp. errCode == BaseResp.ErrCode. ERR_OK) {
 String code = resp. token;
 if(BaseApplication. isWxLogin){
 getToken(code);
 } else{
 WXEntryActivity. this.finish();
 }
 } else{
 WXEntryActivity. this.finish();
 }
 
 }
 //这个方法会取得accesstoken 和openID
 private void getToken(String code){
 MyProgressDialog. showDialog(WXEntryActivity.this, "登陆", "正在获取用户信息" );
 HttpBase. get("https://api.weixin.qq.com/sns/oauth2/access_token?appid=wxd7673d08f6c1963d&secret=223d726f966031f30125d0e4e7d4aed3&code=" +code+"&grant_type=authorization_code" , new JsonHttpResponseHandler(){
 @Override
 public void onSuccess( int statusCode, JSONObject response) {
 super.onSuccess(statusCode, response);
 getUserInfo(response.optString( "access_token"),response.optString( "openid"));
 }
 @Override
 public void onFailure( int statusCode, Throwable e,
   JSONObject errorResponse) {
 // TODO Auto-generated method stub
 super.onFailure(statusCode, e, errorResponse);
 MyProgressDialog. closeDialog();
 }
 });
 }
 
 //获取到token和openID之后,调用此接口得到身份信息
 private void getUserInfo(String token,String openID){
 HttpBase. get("https://api.weixin.qq.com/sns/userinfo?access_token=" +token+"&openid=" +openID, new JsonHttpResponseHandler(){
 @Override
 public void onSuccess( int statusCode, JSONObject response) {
 super.onSuccess(statusCode, response);
 try {
  String nickname = response.getString("nickname");//获取用户微信名
  String sex = response.getInt("sex") == 1 ? "男" : "女";//获取用户性别
  String header = response.getString( "headimgurl");//获取用户头像
 } catch (JSONException e) {
  e.printStackTrace();
 }
 }
 @Override
 public void onFailure( int statusCode, Throwable e,
   JSONObject errorResponse) {
 super.onFailure(statusCode, e, errorResponse);
 MyProgressDialog. closeDialog();//隐藏dialog
 HttpBase. onFailureTips(WXEntryActivity.this, errorResponse);
 }
 });
 }
}

到这里就欧克了!

补充知识:Android接入微信sdk,使用微信授权

接入微信sdk,进行授权,第一个最基本也是最重要的步骤,需要注意应用的包名、应用签名(如果不知道的可以使用新浪签名工具查看,或者微信提供的工具),app id (微信申请成功之后可以获得) 三者必须要与微信上申请的一致,否者将会无法成功调起微信。

1、在自己的项目上创建一个按钮

2、新建一个Constans.java的类,存放微信支付相关的参数

public class Constants {

 public static final String APP_ID = "wxxxxxxx"; //替换为申请到的app id

}

3、在MyApplication.java类里面进行实例化

4、在登录页面注册点击事件 , 跳转微信授

scope 因为是获取用户个人信息所以固定填 snsapi_userinfo

state 可填可不填的参数,按官方建议最好填写,可用于防止csrf攻击(跨站请求伪造攻击)

5、这时候就可以调起微信授权了,但是如果需要得到微信返回的结果,还需要以下的步骤

1)在包名下新增wxapi文件夹(这个文件夹名字是微信官方规定的,必须一致)

2)在wxapi文件夹下新增继承于Activity并实现IWXAPIEventHandler接口的WXEntryActivity类(这个类名是微信官方规定的,必须一致)

if(baseResp instanceof SendAuth.Resp){

 SendAuth.Resp newResp = (SendAuth.Resp) baseResp;

 //获取微信传回的code

 final String code = newResp.code;

}

获得的code就是微信授权成功后给的临时票据,可以根据code获取相关的用户 access_token 和 openid , 然后根据 access_token 和 openid 获取用户信息

6、在AndroidManifest.xml中对WXEntryActivity进行配置

1)增加权限

2)增加WXEntryActivity的配置

其中android:exported="true" 必须加上,否则无法接收回调

7、编译生成运行,即可发起微信登录并得到微信返回。

如果还是不行,注意是否以下问题引起:

1)app id是否正确?

2)包名是否和申请时填写的一致?

3)应用签名是否和申请时填写的一致?(可以用签名生成工具对比一下)通常可能发生的情况是,申请用的签名包,调试用的非签名包,这种情况很常见。

4)WXEntryActivity.java文件的位置是否正确

5)AndroidManifest.xml中的配置是否正确?

6)公众号、移动应用之间统一帐号的话,可利用unionID来满足需求,因为微信返回的openid是根据app id 进行生成的,这样就导致了如果是H5授权那么和Android得到的id不一致

最后附上微信开放平台官方地址:https://open.weixin.qq.com/cgi-bin/showdocument?action=dir_list&t=resource/res_list&verify=1&id=open1419317851&token=&lang=zh_CN

以上这篇使用Android开发接入第三方原生SDK实现微信登录就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

推荐阅读
落单鸟人
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有