新浪微薄分享1(授权)
新浪微薄分享一(授权)
闲来无事,想把项目中用到的第三方组件总结一下,省的以后用到还得重新学习。接下来的一系列文章涉及到的第三方组件有新浪、腾讯、微信等第三方分享和登录,支付宝,个推等。
今天先说一下新浪微薄分享之授权。因为我们一个项目中一般设计到的分享都有好几种,如果都引用对应的sdk的话项目相对比较大。另外sdk官方都推出了Demo,使用起来也比较简单,所以我们这里讲的都是网页接入。
无论是分享还是登录,首先要做的都是获得用户授权。授权目前有两种方式,我们先讲目前推荐的方式,主要分为二步
第一步:请求授权,获取Code
protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.auth); web = (WebView) findViewById(R.id.web); StringBuffer sb = new StringBuffer("https://open.weibo.cn/oauth2/authorize"); sb.append("&client_id=" + Constant.TENCONNECT_APP_ID); try { sb.append("&redirect_uri=" + URLEncoder.encode(Constant.TENCONNECT_REDIRECT_URL, "UTF-8")); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } sb.append("&display=mobile"); web.getSettings().setJavaScriptEnabled(true); web.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { //这里获取的url=http://www.myaddress.com/?code=6f59f37d0212ee969cdc943aa9af9443
String code = getCodeBySubUrl(url);
getAccessToken(code); }); web.loadUrl(sb.toString()); }第二步:通过code,发送post请求,获取授权accessToken
public void getAccessToken(final String code) { new AsyncTask<Object, Object, String>() { @Override protected Json doInBackground(Object... params) { Map<String,String> parameters = new HashMap<String, String> parameters.put("client_id", client_id); parameters.put("client_secret", Contents.REGISTERED_REDIRECT_URI); parameters.put("grant_type", "authorization_code"); parameters.put("code", code); parameters.put("redirect_uri",redirect_uri); byte[] b = HttpClientConnector.getInstance(AuthWebActivity.this).requestByPost("https://api.weibo.com/oauth2/access_token",parameters); String result = new String(b); LogInfo.i(TAG, result); Json json = new Json(result); return json; } @Override protected void onPostExecute(Json result) { if (result != null) { String accessToken = result.getString("access_token"); } super.onPostExecute(result); } }; }