這裡對於App在微信開放平臺上申請AppID和secret在這裡就略過了,我們微信的授權登錄流程,騰訊官網給的流程如下: 1. 第三方發起微信授權登錄請求,微信用戶允許授權第三方應用後,微信會拉起應用或重定向到第三方網站,並且帶上授權臨時票據code參數; 2. 通過code參數加上AppID和Ap ...
這裡對於App在微信開放平臺上申請AppID和secret在這裡就略過了,我們微信的授權登錄流程,騰訊官網給的流程如下:
1. 第三方發起微信授權登錄請求,微信用戶允許授權第三方應用後,微信會拉起應用或重定向到第三方網站,並且帶上授權臨時票據code參數;
2. 通過code參數加上AppID和AppSecret等,通過API換取access_token;
3. 通過access_token進行介面調用,獲取用戶基本數據資源或幫助用戶實現基本操作。
下邊我們看看代碼是怎麼實現的。 源碼地址
一、載入騰訊SDK
開發環境是Android Studio,在build.gradle文件中,添加如下依賴即可:
dependencies {
compile 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:+'
}
二、添加網路及存儲等授權
在AndroidManifest.xml中設置如下許可權:
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
三、代碼
1、初始化IWXApi並註冊到微信
我們這裡是在登錄視窗發起的登錄授權,IWXAPI我們是在Application類中聲明創建的,代碼如下:
public IWXAPI iwxapi;
@Override
public void onCreate() {
super.onCreate();
this.instance=this;
//利用工廠類獲得IWXAPI實例
iwxapi= WXAPIFactory.createWXAPI(this,appID,true);// (this, Constants.APP_ID);
//將應用的AppID註冊到微信
iwxapi.registerApp(appID);
//UMShareAPI.get(this);
}
2、獲取code
環境和初始化完成了,按照騰訊登錄流程,首先要獲取code,代碼如下:
Button wxSignInButton=(Button) findViewById(R.id.wx_sign_in_button);
wxSignInButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View view) {
final SendAuth.Req req = new SendAuth.Req();
req.scope = "snsapi_userinfo";
req.state = "wechat_sdk_demo_test";
GlobalApplication.getInstance().iwxapi.sendReq(req);
}
});
3、創建WXEntryActivity類並獲取Token
WXEntryActivity是騰訊的硬性要求,包名必須為wxapi,我們這裡是:package com.jxkj.solution.solutionandroid.wxapi。WXEntryActivity為Activity子類並且要實現IWXAPIEventHandler介面,用戶獲得登錄請求後微信返回的結果,如果正確會返回code。在onResp中返回code後,直接通過HttpGet方法獲得AccessToken。在onCreate方法中調用handleIntent方法將接收到的intent及實現了IWXAPIEventHandler介面的對象傳遞給IWXAP。
WXEntryActivity在AndroidManifest.xml中的配置:
<!-- 微信 -->
<activity
android:name=".wxapi.WXEntryActivity"
android:exported="true"//必須的
android:theme="@android:style/Theme.Translucent.NoTitleBar" />
WXEntryActivity代碼如下:
public class WXEntryActivity extends Activity implements IWXAPIEventHandler{
private static final int RETURN_MSG_TYPE_LOGIN = 1;
private static final int RETURN_MSG_TYPE_SHARE = 2;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
////必須調用此句話,否則回調不起作用
GlobalApplication.getInstance().iwxapi.handleIntent(getIntent(),WXEntryActivity.this);
}
@Override
public void onReq(BaseReq baseReq) {
switch (baseReq.getType()) {
case ConstantsAPI.COMMAND_GETMESSAGE_FROM_WX:
break;
case ConstantsAPI.COMMAND_SHOWMESSAGE_FROM_WX:
break;
default:
break;
}
}
@Override
public void onResp(com.tencent.mm.opensdk.modelbase.BaseResp baseResp) {
Toast.makeText(this, "baseresp.getType = " + baseResp.getType(), Toast.LENGTH_SHORT).show();
switch (baseResp.errCode) {
case com.tencent.mm.opensdk.modelbase.BaseResp.ErrCode.ERR_OK:
switch (baseResp.getType()) {
case RETURN_MSG_TYPE_LOGIN:
//拿到了微信返回的code,立馬再去請求access_token
String code = ((SendAuth.Resp) baseResp).code;
try {
//獲取access_token為http get請求
String res= OkhttpUtils.getSyncAsString("https://api.weixin.qq.com/sns/oauth2/access_token?appid=AppID&secret=AppSecret&code="; + code + "&grant_type=authorization_code");
Toast.makeText(this, res, Toast.LENGTH_LONG).show();
} catch (IOException e) {
e.printStackTrace();
}
Toast.makeText(this, code, Toast.LENGTH_LONG).show();
//就在這個地方,用網路庫什麼的或者自己封的網路api,發請求去咯,註意是get請求
break;
case RETURN_MSG_TYPE_SHARE:
break;
}
break;
case com.tencent.mm.opensdk.modelbase.BaseResp.ErrCode.ERR_USER_CANCEL:
break;
case com.tencent.mm.opensdk.modelbase.BaseResp.ErrCode.ERR_AUTH_DENIED:
break;
case com.tencent.mm.opensdk.modelbase.BaseResp.ErrCode.ERR_UNSUPPORT:
break;
default:
break;
}
}
}
四、微信登錄、分享等一些需要註意的問題
微信第三方登錄、分享等代碼寫起來不多也不難,但需要遵循騰訊規定的步驟嚴格執行,在做的過程有如下問題需要註意:
1、AppID和AppSecret必須和平臺一致
2、簽名需要保持一致,對於簽名的生成的問題可以查看 文章鏈接地址“Android集成微信分享功能應用簽名生成方法及分享不生效的問題”