国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

使用Android開發(fā)接入第三方原生SDK實現(xiàn)微信登錄

瀏覽:92日期:2022-06-08 09:02:39

微信開放平臺 : https://open.weixin.qq.com/

一、準備工作 :

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

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

2. 在清單文件AndroidManifest.xml中加入權(quán)限:

<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. 注冊微信:

想要使我們的程序啟動之后,微信終端可以響應(yīng)我們我們的程序的話.就必須在代碼中像微信終端注冊我們的id

(可以在程序的入口Activity的OnCreat中注冊,也可以在MyApplication中,或者是在其他合適的地方將我們的應(yīng)用id注冊到微信),此處在Application中:

// 1.聲明一個statid的IWXAPI 以及APPIDprivate static IWXAPI mWxApi;private String WX_APPID = ''; // 2.初始化微信SDKmWxApi = 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中聲明該類:

<!-- 注冊微信回調(diào) 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); //必須調(diào)用此句話 } @Override protected void onNewIntent(Intent intent) { super.onNewIntent(intent); BaseApplication. mIwapi.handleIntent(intent, WXEntryActivity.this);//必須調(diào)用此句話 } @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之后調(diào)用https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code 獲取到token和openID。 * 之后再調(diào)用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之后,需要調(diào)用接口獲取到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之后,調(diào)用此接口得到身份信息 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,使用微信授權(quán)

接入微信sdk,進行授權(quán),第一個最基本也是最重要的步驟,需要注意應(yīng)用的包名、應(yīng)用簽名(如果不知道的可以使用新浪簽名工具查看,或者微信提供的工具),app id (微信申請成功之后可以獲得) 三者必須要與微信上申請的一致,否者將會無法成功調(diào)起微信。

1、在自己的項目上創(chuàng)建一個按鈕

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

public class Constants { public static final String APP_ID = 'wxxxxxxx'; //替換為申請到的app id}

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

4、在登錄頁面注冊點擊事件 , 跳轉(zhuǎn)微信授

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

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

5、這時候就可以調(diào)起微信授權(quán)了,但是如果需要得到微信返回的結(jié)果,還需要以下的步驟

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就是微信授權(quán)成功后給的臨時票據(jù),可以根據(jù)code獲取相關(guān)的用戶 access_token 和 openid , 然后根據(jù) access_token 和 openid 獲取用戶信息

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

1)增加權(quán)限

2)增加WXEntryActivity的配置

其中android:exported='true' 必須加上,否則無法接收回調(diào)

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

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

1)app id是否正確?

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

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

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

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

6)公眾號、移動應(yīng)用之間統(tǒng)一帳號的話,可利用unionID來滿足需求,因為微信返回的openid是根據(jù)app id 進行生成的,這樣就導(dǎo)致了如果是H5授權(quán)那么和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開發(fā)接入第三方原生SDK實現(xiàn)微信登錄就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: 微信
相關(guān)文章:
主站蜘蛛池模板: 国产区一区二区三 | 中美日韩在线网免费毛片视频 | 欧美日韩精品一区二区三区视频在线 | 久久高清一区二区三区 | 欧美大尺度aaa级毛片 | 私人玩物福利 | 宅男69免费永久网站 | 国产一区二区三区在线观看免费 | 天天爽夜夜操 | a毛片视频 | 黄色三级网络 | 国产一级免费片 | 91精品乱码一区二区三区 | 亚洲一区二区三区四区五区六区 | 二区国产 | 一区二区免费看 | 一个人免费观看日本www视频 | 日韩免费观看的一级毛片 | 一级毛片美国aaj毛片 | 亚洲一区二区在线视频 | 欧美一级久久久久久久久大 | 成人涩涩屋福利视频 | 国产一区二区精品久 | 黄免费看| 国产高清一区二区三区四区 | 亚洲一级毛片免费看 | 欧美日本韩国一区 | 久久久久久久久久毛片精品美女 | 国产成人教育视频在线观看 | yy6080久久亚洲精品 | 成人免费福利网站在线看 | 久草视频在线播放 | 怡红院老首页主页入口 | 亚洲美女精品视频 | 中文精品99久久国产 | 午夜毛片视频高清不卡免费 | 国产成人久久精品 | 美女视频黄色的免费 | 久久综合给合久久狠狠狠97色69 | 国产精品揄拍一区二区 | 国产在线日韩在线 |