Android App实现第三方微信登录

                         Android App实现第三方微信登录

 

1、下载微信官方最新sdk,集成到app。如下图:

Android App实现第三方微信登录 - 好灵敏 - 好灵敏的空间

 

 

2、注册到微信

可以在app的某个ActivityonCreate方法中注册,这里也可以在appapplicationonCreate()方法中注册,这样,在整个app的中都可以使用。例如:

public class CarApplication  extends Application{

…… …… ……

public static IWXAPI api;

public void onCreate() {

//注册微信

api = WXAPIFactory.createWXAPI(this, 你的应用在微信上申请的app_id”true); 

api.registerApp(你的应用在微信上申请的app_id”);

…… …… ……

}

}

 

3、在app的包名目录下新建一个wxapi目录,然后在此目录下新建WXEntryActivity.java文件,如下,app的包名为carjob.com.cn,新建的wxapi目录如下。注意:一定是包名目录下新建,不要在其他目录新建,否则WXEntryActivity.java里的public void onResp(BaseResp resp)方法不会被调用

Android App实现第三方微信登录 - 好灵敏 - 好灵敏的空间

 

WXEntryActivity继承Activity,实现IWXAPIEventHandler,并重写protected void onNewIntent(Intent intent)public void onReq(BaseReq arg0)public void onResp(BaseResp resp)方法。WXEntryActivity.java文件可以见最后附录。

 

4、发送微信登录的请求

app中点击某一个view,发送微信登录的请求如下:

final SendAuth.Req req = new SendAuth.Req();

req.scope = "snsapi_userinfo";

req.state = "carjob_wx_login";

CarApplication.api.sendReq(req);

其中,CarApplication.api就是第2步中注册的IWXAPI对象。

请求成功后,可拉起微信的授权登录页面,如下。用户点击“确认登录”后,SDK通过SendAuthResp返回数据给调用方(即app),此时WXEntryActivity中的public void onResp(BaseResp resp)方法被调用(微信、朋友圈分享成功后,此方法同样会被调用),微信登录的返回值说明如下。这里app可以做相关的处理,见WXEntryActivity.java文件中的处理,取code为下一步获取access_tokenopenid等信息做准备。此处获取code的方法:

public void onResp(BaseResp resp) {

switch (resp.errCode) {

case BaseResp.ErrCode.ERR_OK:

String code = ((SendAuth.Resp) resp).code; //即为所需的code

break;

…… …… …… 

}

}

Android App实现第三方微信登录 - 好灵敏 - 好灵敏的空间

 

Android App实现第三方微信登录 - 好灵敏 - 好灵敏的空间

 

 

 

5、通过code获取access_token

获取上一步中的code后,调用以下接口获取access_token,官方指出用Get方式请求。

https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

请求参数说明







appid应用唯一标识,在微信开放平台提交应用审核通过后获得

secret应用密钥AppSecret,在微信开放平台提交应用审核通过后获得

code填写第一步获取的code参数

grant_typeauthorization_code

返回说明

正确的返回:


"access_token":"ACCESS_TOKEN", 
"expires_in":7200, 
"refresh_token":"REFRESH_TOKEN",
"openid":"OPENID", 
"scope":"SCOPE" 
}

返回参数说明:

access_token接口调用凭证

expires_inaccess_token接口调用凭证超时时间,单位(秒)

refresh_token用户刷新access_token

openid授权用户唯一标识

scope用户授权的作用域,使用逗号(,)分隔

 

6、获得access_tokenopenid后,app就可以根据自己的规则与互自己的server进行交互。

 

7、微信请求的一般流程如下:

Android App实现第三方微信登录 - 好灵敏 - 好灵敏的空间

 

 

 

附录:

WXEntryActivity.java

 

package carjob.com.cn.wxapi;

import carjob.com.cn.CarApplication;

import carjob.com.cn.newversion.MyResumeLoginView;

import carjob.com.cn.search.SharedPreferencesclass;

import carjob.com.cn.util.SharedPreferenceUtil;

 

import com.tencent.mm.sdk.constants.ConstantsAPI;

import com.tencent.mm.sdk.modelbase.BaseReq;

import com.tencent.mm.sdk.modelbase.BaseResp;

import com.tencent.mm.sdk.modelmsg.SendAuth;

import com.tencent.mm.sdk.openapi.IWXAPIEventHandler;

 

import android.app.Activity;

import android.content.Context;

import android.content.Intent;

import android.os.Bundle;

import android.widget.Toast;

 

public class WXEntryActivity extends Activity implements IWXAPIEventHandler {

private Context context = WXEntryActivity.this;

 

private void handleIntent(Intent paramIntent) {

CarApplication.api.handleIntent(paramIntent, this);

}


@Override

protected void onCreate(Bundle savedInstanceState) {

// TODO Auto-generated method stub

super.onCreate(savedInstanceState);

handleIntent(getIntent());

}


@Override

protected void onNewIntent(Intent intent) {

// TODO Auto-generated method stub

super.onNewIntent(intent);

setIntent(intent);

handleIntent(intent);

}


@Override

public void onReq(BaseReq arg0) {

// TODO Auto-generated method stub

finish();

}

 

@Override

public void onResp(BaseResp resp) {

// TODO Auto-generated method stub

switch (resp.errCode) {

case BaseResp.ErrCode.ERR_OK:

if (ConstantsAPI.COMMAND_SENDMESSAGE_TO_WX == resp.getType()) {

Toast.makeText(context, "分享成功", Toast.LENGTH_LONG).show();

break;

}

String code = ((SendAuth.Resp) resp).code;

new SharedPreferencesclass(49, code, context);

        System.out.println("微信确认登录返回的code" + code);

        Toast.makeText(context, "微信确认登录返回的code" + code, Toast.LENGTH_LONG).show();

MyResumeLoginView.loginHandler.sendEmptyMessage(MyResumeLoginView.WEIXIN_LOGIN_SUCCESS);

        break;

case BaseResp.ErrCode.ERR_USER_CANCEL:

break;

case BaseResp.ErrCode.ERR_AUTH_DENIED:

break;

default:

break;

}

finish();

}


}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章