溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Android中通過接入第三方原生SDK實現(xiàn)一個微信登錄功能

發(fā)布時間:2021-03-20 15:19:20 來源:億速云 閱讀:147 作者:Leah 欄目:移動開發(fā)

這篇文章將為大家詳細講解有關怎么在Android中通過接入第三方原生SDK實現(xiàn)一個微信登錄功能,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

一、準備工作 :

1. Android Studio環(huán)境下:在build.gradle文件中,添加如下依賴即可:

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

2. 在清單文件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. 注冊微信:

想要使我們的程序啟動之后,微信終端可以響應我們我們的程序的話.就必須在代碼中像微信終端注冊我們的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. 發(fā)起登錄

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的類,這個類名和包名是微信規(guī)定的,木有辦法,必須一致了

然后在清單文件AndroidManifest.xml中聲明該類:

<!-- 注冊微信回調 WXEntryActivity -->
<activity
 android:name=".wxapi.WXEntryActivity"
 android:configChanges="keyboardHidden|orientation|screenSize"
 android:exported="true"
 android:screenOrientation="portrait"
 android:theme="@style/NoTitleTranslucentTheme">
</activity>

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/oauth3/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/oauth3/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、在自己的項目上創(chuàng)建一個按鈕

2、新建一個Constans.java的類,存放微信支付相關的參數(shù)

public class Constants {

 public static final String APP_ID = "wxxxxxxx"; //替換為申請到的app id

}

3、在MyApplication.java類里面進行實例化

4、在登錄頁面注冊點擊事件 , 跳轉微信授

scope 因為是獲取用戶個人信息所以固定填 snsapi_userinfo

state 可填可不填的參數(shù),按官方建議最好填寫,可用于防止csrf攻擊(跨站請求偽造攻擊)

5、這時候就可以調起微信授權了,但是如果需要得到微信返回的結果,還需要以下的步驟

1)在包名下新增wxapi文件夾(這個文件夾名字是微信官方規(guī)定的,必須一致)

2)在wxapi文件夾下新增繼承于Activity并實現(xiàn)IWXAPIEventHandler接口的WXEntryActivity類(這個類名是微信官方規(guī)定的,必須一致)

if(baseResp instanceof SendAuth.Resp){

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

 //獲取微信傳回的code

 final String code = newResp.code;

}

獲得的code就是微信授權成功后給的臨時票據(jù),可以根據(jù)code獲取相關的用戶 access_token 和 openid , 然后根據(jù) access_token 和 openid 獲取用戶信息

6、在AndroidManifest.xml中對WXEntryActivity進行配置

1)增加權限

2)增加WXEntryActivity的配置

其中android:exported="true" 必須加上,否則無法接收回調

7、編譯生成運行,即可發(fā)起微信登錄并得到微信返回。

如果還是不行,注意是否以下問題引起:

1)app id是否正確?

2)包名是否和申請時填寫的一致?

3)應用簽名是否和申請時填寫的一致?(可以用簽名生成工具對比一下)通??赡馨l(fā)生的情況是,申請用的簽名包,調試用的非簽名包,這種情況很常見。

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

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

6)公眾號、移動應用之間統(tǒng)一帳號的話,可利用unionID來滿足需求,因為微信返回的openid是根據(jù)app id 進行生成的,這樣就導致了如果是H5授權那么和Android得到的id不一致

關于怎么在Android中通過接入第三方原生SDK實現(xiàn)一個微信登錄功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI