詳解Android微信登錄與分享
Android 使用微信登錄、分享功能
具體的文檔詳情微信官網(wǎng)上介紹(微信官網(wǎng)文檔),本人直接按照項(xiàng)目部署步驟進(jìn)行講解:
第一步:申請(qǐng)你的AppID;
第二步:依賴
dependencies {
compile 'com.tencent.mm.opensdk:wechat-sdk-android-with-mta:1.0.2'
}
或者:
dependencies {
compile 'com.tencent.mm.opensdk:wechat-sdk-android-without-mta:1.0.2'
}
這兩個(gè)依賴包的區(qū)別是前者包含統(tǒng)計(jì)功能,后者沒有。
第三步:在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"/>
第四步:注冊(cè)到微信,微信的SDK在使用之前需要調(diào)用代碼進(jìn)行注冊(cè),注冊(cè)可以是在調(diào)用微信SDK的Activity,但最好還是放到入口Activity或者Application中;
WxApplication.java
public static String APP_ID="你的APPID";
public static IWXAPI api;
public void onCreate() {
super.onCreate();
api = WXAPIFactory.createWXAPI(this, APP_ID, true);
api.registerApp(APP_ID);
}
第五步:微信登錄。
5.1 點(diǎn)擊你的微信登錄按鈕,進(jìn)行微信授權(quán),首先需要獲取一個(gè)code值,在包名下新建一個(gè)包,這里必須這樣,不能隨意命名,比如你的項(xiàng)目包名是:come.shenhua.wx則新建的包為come.shenhua.wx.wxapi在該包下創(chuàng)建一個(gè)WXEntryActivity繼承IWXAPIEventHandler;(注意Activity的命名也不能隨意更改)
LoginActivity.java
private void onClickWeChatLogin() {
if (WxApplicaiton.api == null) {
WxApplication.api = WXAPIFactory.createWXAPI(this, WxApplication.APP_ID, true);
}
if (!WxApplication.api.isWXAppInstalled()) {
ToastUtils.toast("您手機(jī)尚未安裝微信,請(qǐng)安裝后再登錄");
return;
}
WxApplication.api.registerApp(WxApplication.APP_ID);
SendAuth.Req req = new SendAuth.Req();
req.scope = "snsapi_userinfo";
req.state = "wechat_sdk_xb_live_state";//官方說明:用于保持請(qǐng)求和回調(diào)的狀態(tài),授權(quán)請(qǐng)求后原樣帶回給第三方。該參數(shù)可用于防止csrf攻擊(跨站請(qǐng)求偽造攻擊),建議第三方帶上該參數(shù),可設(shè)置為簡單的隨機(jī)數(shù)加session進(jìn)行校驗(yàn)
WxApplication.api.sendReq(req);
}
在AndroidManifest.xml中加入,(android:exported="true" 一定不能少)
<activity android:name=".wxapi.WXEntryActivity" android:exported="true" />
WXEntryActivity.java
public class WXEntryActivity extends AppCompatActivity implements IWXAPIEventHandler {
public static final String TAG = WXEntryActivity.class.getSimpleName();
public static String code;
public static BaseResp resp = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_wxentry);
boolean handleIntent = XBLiveApplication.api.handleIntent(getIntent(), this);
//下面代碼是判斷微信分享后返回WXEnteryActivity的,如果handleIntent==false,說明沒有調(diào)用IWXAPIEventHandler,則需要在這里銷毀這個(gè)透明的Activity;
if(handleIntent==false){
Log.d(TAG, "onCreate: "+handleIntent);
finish();
}
}
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
XBLiveApplication.api.handleIntent(intent, this);
}
@Override
public void onReq(BaseReq baseReq) {
Log.d(TAG, "onReq: ");
finish();
}
@Override
public void onResp(BaseResp baseResp) {
if (baseResp != null) {
resp = baseResp;
code = ((SendAuth.Resp) baseResp).code; //即為所需的code
}
switch (baseResp.errCode) {
case BaseResp.ErrCode.ERR_OK:
Log.d(TAG, "onResp: 成功");
finish();
break;
case BaseResp.ErrCode.ERR_USER_CANCEL:
Log.d(TAG, "onResp: 用戶取消");
finish();
break;
case BaseResp.ErrCode.ERR_AUTH_DENIED:
Log.d(TAG, "onResp: 發(fā)送請(qǐng)求被拒絕");
finish();
break;
}
}
resp和code定義成全局變量,在WXEntryWActivity頁面銷毀后登錄頁面會(huì)走onResume()方法,在這里開始其他操作
5.2 拿到code后在登錄頁面通過code獲取access_token,官網(wǎng)的說法是:“access_token是調(diào)用授權(quán)關(guān)系接口的調(diào)用憑證,由于access_token有效期(目前為2個(gè)小時(shí))較短,當(dāng)access_token超時(shí)后,可以使用refresh_token進(jìn)行刷新”,所以拿到access_token后再次請(qǐng)求進(jìn)行refresh_token,刷新后拿到access_token即可發(fā)送請(qǐng)求獲取微信用戶信息了;
獲取access_token的URL:AccessTokenUrl = "
刷新access_token的URL:Refresh_tokenUrl = "https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=你的appid&grant_type=refresh_token&refresh_token=上一步請(qǐng)求到的access_token; 獲取用戶信息URL:UserInfoUrl = "https://api.weixin.qq.com/sns/userinfo?access_token=刷新的access_token&openid=刷新access_token時(shí)獲取的openid; 注意一點(diǎn):在做測試時(shí),微信的應(yīng)用簽名必須要保持一致,比如你在官網(wǎng)填寫的是沒有打包簽名的應(yīng)用簽名,你測試的APP也沒有打包簽名,那么是沒有問題,但是如果你微信官網(wǎng)上填寫的是已經(jīng)上線經(jīng)過打包簽名的應(yīng)用簽名,那你在做測試時(shí)必須要用打包簽名的應(yīng)用去做測試。 第六步:微信分享到朋友圈: 第七步:微信分享到微信好友: 以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!
@Override
protected void onResume() {
Log.d(TAG, "onResume: 1");
super.onResume();
//這里的判斷是為了區(qū)分如果不是不是從WXEntryActivity頁面銷毀重啟的,不走下面的代碼
if (WXEntryActivity.resp != null) {
if (WXEntryActivity.resp.getType() == ConstantsAPI.COMMAND_SENDAUTH) {
Thread thread = new Thread(downloadRun);
thread.start();
try {
thread.join();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
public Runnable downloadRun = new Runnable() {
@Override
public void run() {
WXGetAccessToken();
}
};
//根據(jù)code獲取access_token,這里用第三方volley框架進(jìn)行post請(qǐng)求
private void WXGetAccessToken() {
String getAccessTokenUrl = AccessTokenUrl;
StringRequest request = new StringRequest(Request.Method.GET, getAccessTokenUrl, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.d(TAG, "onResponse: " + response);
Gson gson = new Gson();
WeChatLoginTokenModel tokenModel = gson.fromJson(response, WeChatLoginTokenModel.class);
refresh_token = tokenModel.getRefresh_token();
WXGetRefreshAccessToken();
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
}
});
request.setTag("weChatGetToken");
XBLiveApplication.getHttpRequestQueue().add(request);
}
//拿到access_token后再次發(fā)送請(qǐng)求進(jìn)行刷新access_token,拿到access_refresh和openid
private void WXGetRefreshAccessToken() {
String getRefresh_tokenUrl =Refresh_tokenUrl ;
StringRequest request = new StringRequest(Request.Method.GET, getRefresh_tokenUrl, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Gson gson = new Gson();
WeChatLoginTokenModel tokenModel = gson.fromJson(response, WeChatLoginTokenModel.class);
String access_token = tokenModel.getAccess_token();
String openid = tokenModel.getOpenid();
WXGetUserInfo(access_token, openid);
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
}
});
request.setTag("weChatGetRefreshToken");
XBLiveApplication.getHttpRequestQueue().add(request);
}
//獲取用戶信息
private void WXGetUserInfo(String access_token, String openid) {
String getUserInfoUrl =UserInfoUr;
StringRequest request = new StringRequest(Request.Method.GET, getUserInfoUrl, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
Log.d(TAG, "onResponse3: " + response);
Gson gson = new Gson();
WeChatUserInfoModel userInfoModel = gson.fromJson(response, WeChatUserInfoModel.class);
String city = userInfoModel.getCity();
String userName = userInfoModel.getNickname();
String userIcon = userInfoModel.getHeadimgurl();
int sex = userInfoModel.getSex();//1:男;0:女;2:未知
String province = userInfoModel.getProvince();
openId_WX = userInfoModel.getOpenid();
ToastUtils.toast("登錄成功");
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
}
});
//下面代碼是volley框架注冊(cè),請(qǐng)忽視
request.setTag("weChatGetUserInfo");
XBLiveApplication.getHttpRequestQueue().add(request);
}
相關(guān)文章
Jetpack?Compose慣性衰減動(dòng)畫AnimateDecay詳解
這篇文章主要為大家介紹了Jetpack?Compose慣性衰減動(dòng)畫AnimateDecay詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
android實(shí)現(xiàn)簡單進(jìn)度條ProgressBar效果
這篇文章主要為大家詳細(xì)介紹了android實(shí)現(xiàn)簡單進(jìn)度條ProgressBar效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
強(qiáng)制Android應(yīng)用使用某個(gè)Locale的方法
這篇文章主要介紹了強(qiáng)制Android應(yīng)用使用某個(gè)Locale的方法,涉及Android基于Locale進(jìn)行語言設(shè)置的相關(guān)技巧,需要的朋友可以參考下2015-10-10
靈活使用Android中ActionBar和ViewPager切換頁面
這篇文章主要介紹了如何靈活使用Android中ActionBar和ViewPager切換頁面,感興趣的小伙伴們可以參考一下2015-12-12
Android實(shí)現(xiàn)簡單計(jì)算器界面
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)簡單計(jì)算器界面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01
Android仿新聞頂部導(dǎo)航標(biāo)簽切換效果
這篇文章主要為大家詳細(xì)介紹了Android仿新聞頂部導(dǎo)航標(biāo)簽切換效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11
Android實(shí)現(xiàn)后臺(tái)開啟服務(wù)默默拍照功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)后臺(tái)開啟服務(wù)默默拍照功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-06-06
深入探究Android動(dòng)態(tài)代理的原理及用途
動(dòng)態(tài)代理是一種在編程中非常有用的設(shè)計(jì)模式,它允許你在運(yùn)行時(shí)創(chuàng)建一個(gè)代理對(duì)象來代替原始對(duì)象,以便在方法調(diào)用前后執(zhí)行額外的邏輯,本文將深入探討Android動(dòng)態(tài)代理的原理、用途和實(shí)際示例2023-09-09

