詳解Android微信登入與分享,詳解android分享

來源:互聯網
上載者:User

詳解Android登入與分享,詳解android分享

Android 使用登入、分享功能

具體的文檔詳情官網上介紹(官網文檔),本人直接按照項目部署步驟進行講解:

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

這兩個依賴包的區別是前者包含統計功能,後者沒有。

第三步:在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在使用之前需要調用代碼進行註冊,註冊可以是在調用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在該包下建立一個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";//官方說明:用於保持請求和回調的狀態,授權請求後原樣帶回給第三方。該參數可用於防止csrf攻擊(跨站請求偽造攻擊),建議第三方帶上該參數,可設定為簡單的隨機數加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,說明沒有調用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: 發送請求被拒絕"); finish(); break; } }

resp和code定義成全域變數,在WXEntryWActivity頁面銷毀後登入頁面會走onResume()方法,在這裡開始其他動作

  5.2 拿到code後在登入頁面通過code擷取access_token,官網的說法是:“access_token是調用授權關係介面的調用憑證,由於access_token有效期間(目前為2個小時)較短,當access_token逾時後,可以使用refresh_token進行重新整理”,所以拿到access_token後再次請求進行refresh_token,重新整理後拿到access_token即可發送請求擷取使用者資訊了;

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

  重新整理access_token的URL:Refresh_tokenUrl = "https://api.weixin.qq.com/sns/oauth2/refresh_token?appid=你的appid&grant_type=refresh_token&refresh_token=上一步請求到的access_token;

  擷取使用者資訊URL:UserInfoUrl = "https://api.weixin.qq.com/sns/userinfo?access_token=重新整理的access_token&openid=重新整理access_token時擷取的openid;

 @Override    protected void onResume() {        Log.d(TAG, "onResume: 1");        super.onResume();        //這裡的判斷是為了區分如果不是不是從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();        }    };    //根據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後再次發送請求進行重新整理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); }

 

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

 第六步:分享到朋友圈:

 

第七步:分享到好友:

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.