本篇文章給大家分享的是有關(guān)Android開(kāi)發(fā)中實(shí)現(xiàn)登錄微信與分享的方法,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
創(chuàng)新互聯(lián)建站網(wǎng)站建設(shè)公司,提供網(wǎng)站設(shè)計(jì)制作、成都做網(wǎng)站,網(wǎng)頁(yè)設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);可快速的進(jìn)行網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,是專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
第一步:申請(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ì)功能,后者沒(méi)有。
第三步:在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";//官方說(shuō)明:用于保持請(qǐng)求和回調(diào)的狀態(tài),授權(quán)請(qǐng)求后原樣帶回給第三方。該參數(shù)可用于防止csrf攻擊(跨站請(qǐng)求偽造攻擊),建議第三方帶上該參數(shù),可設(shè)置為簡(jiǎn)單的隨機(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,說(shuō)明沒(méi)有調(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頁(yè)面銷毀后登錄頁(yè)面會(huì)走onResume()方法,在這里開(kāi)始其他操作
5.2 拿到code后在登錄頁(yè)面通過(guò)code獲取access_token,官網(wǎng)的說(shuō)法是:“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 = "https://api.weixin.qq.com/sns/oauth3/access_token?appid=你的appid&secret=你的AppSecret&code=授權(quán)獲取到的code&grant_type=authorization_code";
刷新access_token的URL:Refresh_tokenUrl = "https://api.weixin.qq.com/sns/oauth3/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;
@Override protected void onResume() { Log.d(TAG, "onResume: 1"); super.onResume(); //這里的判斷是為了區(qū)分如果不是不是從WXEntryActivity頁(yè)面銷毀重啟的,不走下面的代碼 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); }
注意一點(diǎn):在做測(cè)試時(shí),微信的應(yīng)用簽名必須要保持一致,比如你在官網(wǎng)填寫(xiě)的是沒(méi)有打包簽名的應(yīng)用簽名,你測(cè)試的APP也沒(méi)有打包簽名,那么是沒(méi)有問(wèn)題,但是如果你微信官網(wǎng)上填寫(xiě)的是已經(jīng)上線經(jīng)過(guò)打包簽名的應(yīng)用簽名,那你在做測(cè)試時(shí)必須要用打包簽名的應(yīng)用去做測(cè)試。
第六步:微信分享到朋友圈:
第七步:微信分享到微信好友:
以上就是Android開(kāi)發(fā)中實(shí)現(xiàn)登錄微信與分享的方法,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
當(dāng)前名稱:Android開(kāi)發(fā)中實(shí)現(xiàn)登錄微信與分享的方法
路徑分享:http://jinyejixie.com/article20/ggecco.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開(kāi)發(fā)、網(wǎng)站導(dǎo)航、虛擬主機(jī)、全網(wǎng)營(yíng)銷推廣、外貿(mào)網(wǎng)站建設(shè)、小程序開(kāi)發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)