溫馨提示×

溫馨提示×

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

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

Android開發(fā)中實現(xiàn)登錄微信與分享的方法

發(fā)布時間:2020-11-20 16:41:30 來源:億速云 閱讀:1494 作者:Leah 欄目:移動開發(fā)

本篇文章給大家分享的是有關Android開發(fā)中實現(xiàn)登錄微信與分享的方法,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

第一步:申請你的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'
}

這兩個依賴包的區(qū)別是前者包含統(tǒng)計功能,后者沒有。

第三步:在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"/>

第四步:注冊到微信,微信的SDK在使用之前需要調(diào)用代碼進行注冊,注冊可以是在調(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 點擊你的微信登錄按鈕,進行微信授權,首先需要獲取一個code值,在包名下新建一個包,這里必須這樣,不能隨意命名,比如你的項目包名是:come.shenhua.wx則新建的包為come.shenhua.wx.wxapi在該包下創(chuàng)建一個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("您手機尚未安裝微信,請安裝后再登錄");
   return;
  }
  WxApplication.api.registerApp(WxApplication.APP_ID);
  SendAuth.Req req = new SendAuth.Req();
  req.scope = "snsapi_userinfo";
  req.state = "wechat_sdk_xb_live_state";//官方說明:用于保持請求和回調(diào)的狀態(tài),授權請求后原樣帶回給第三方。該參數(shù)可用于防止csrf攻擊(跨站請求偽造攻擊),建議第三方帶上該參數(shù),可設置為簡單的隨機數(shù)加session進行校驗
  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,則需要在這里銷毀這個透明的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ā)送請求被拒絕");
    finish();
    break;
  }
 }

resp和code定義成全局變量,在WXEntryWActivity頁面銷毀后登錄頁面會走onResume()方法,在這里開始其他操作

    5.2 拿到code后在登錄頁面通過code獲取access_token,官網(wǎng)的說法是:“access_token是調(diào)用授權關系接口的調(diào)用憑證,由于access_token有效期(目前為2個小時)較短,當access_token超時后,可以使用refresh_token進行刷新”,所以拿到access_token后再次請求進行refresh_token,刷新后拿到access_token即可發(fā)送請求獲取微信用戶信息了;

    獲取access_token的URL:AccessTokenUrl = "https://api.weixin.qq.com/sns/oauth3/access_token&#63;appid=你的appid&secret=你的AppSecret&code=授權獲取到的code&grant_type=authorization_code";

    刷新access_token的URL:Refresh_tokenUrl = "https://api.weixin.qq.com/sns/oauth3/refresh_token&#63;appid=你的appid&grant_type=refresh_token&refresh_token=上一步請求到的access_token;

    獲取用戶信息URL:UserInfoUrl = "https://api.weixin.qq.com/sns/userinfo&#63;access_token=刷新的access_token&openid=刷新access_token時獲取的openid;

@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框架進行post請求
 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ā)送請求進行刷新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框架注冊,請忽視
  request.setTag("weChatGetUserInfo");
  XBLiveApplication.getHttpRequestQueue().add(request);
 }

注意一點:在做測試時,微信的應用簽名必須要保持一致,比如你在官網(wǎng)填寫的是沒有打包簽名的應用簽名,你測試的APP也沒有打包簽名,那么是沒有問題,但是如果你微信官網(wǎng)上填寫的是已經(jīng)上線經(jīng)過打包簽名的應用簽名,那你在做測試時必須要用打包簽名的應用去做測試。

第六步:微信分享到朋友圈:

第七步:微信分享到微信好友:

以上就是Android開發(fā)中實現(xiàn)登錄微信與分享的方法,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學到更多知識。更多詳情敬請關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

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

AI