之前发表过博文说明了如何使用基于OAUTH2.0新浪微博认证以及登陆
链接如下:http://blog.csdn.net/geniuseoe2012/article/details/7727564
今天也来侃侃如何使用基于OAUTH2.0的腾讯微博认证以及登陆
网上其实也有不少例子,但很多都是基于OAUTH1.0的认证
然后SDK包会有很多显得异常臃肿,有些童鞋并不是做的腾讯微博客户端之类的软件
而只是需要用到其分享到腾讯微博的小功能而已,那么导入如此之多的jar包实在是没有必要
而且官方出了2.0的认证,对SDK也作了很多精简,我们自然也要与时俱进了
故此小编特地研究了下官方API文档和DEMO,在SDK基础上作了简单封装方便童鞋们使用
这里对于如何开发腾讯微博的基础知识就不作普及了,大家看官方文档就OK了
http://wiki.open.t.qq.com/index.php/%E7%A7%BB%E5%8A%A8%E5%BA%94%E7%94%A8%E6%8E%A5%E5%85%A5/Android_SDK_V1.2
下面上几张效果图:
其实不同微博它们的认证过程都是大同小异
我们在认证页面认证通过后需要获得三个值:
access_token 授权码
openid 用户统一标识 ,可以唯一标识一个用户
openkey 与openid对应的用户key,是验证openid身份的验证密钥
得到这三个值后将其保存到数据库,下次再进入应用的时候,将其设入OAuthV2即可(本例采用2.0认证,故接口调用均涉及到此类)
先看看webview认证页面代码:
public class OAuthV2WebViewActivity extends Activity {
private final CommonLog log = LogFactory.createLog();
private View progressBar;
private Context mContext;
private WebView mWebView;
private WebViewClient mWebViewClient;
private QQWeiboProxy mQqWeiboProxy;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.webview_layout);
mContext = this;
initView();
initData();
}
private void initView()
{
mWebView = (WebView) findViewById(R.id.webview);
mWebView.setVerticalScrollBarEnabled(false);
mWebView.setHorizontalScrollBarEnabled(false);
mWebView.requestFocus();
WebSettings webSettings = mWebView.getSettings();
webSettings.setJavaScriptEnabled(true);
webSettings.setBuiltInZoomControls(true);
webSettings.setSupportZoom(true);
webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
progressBar = findViewById(R.id.show_request_progress_bar);
}
private void initData()
{
mWebViewClient = new WeiboWebViewClient();
mWebView.setWebViewClient(mWebViewClient);
CookieSyncManager.createInstance(this);
mQqWeiboProxy = QQWeiboProxy.getInstance();
String urlStr = mQqWeiboProxy.getAuthoUrl();
mWebView.requestFocus();
mWebView.loadUrl(urlStr);
}
private void showProgress()
{
runOnUiThread(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
progressBar.setVisibility(View.VISIBLE);
}
});
}
private void hideProgress()
{
runOnUiThread(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
progressBar.setVisibility(View.INVISIBLE);
}
});
}
private class WeiboWebViewClient extends WebViewClient
{
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
showProgress();
log.e("onPageStarted URL = " + url);
if (url.indexOf("access_token=") != -1) {
int start=url.indexOf("access_token=");
String responseData=url.substring(start);
boolean ret = mQqWeiboProxy.parseAccessTokenAndOpenId(responseData);
if (ret)
{
String access_token = mQqWeiboProxy.getAccessToken();
String expires_in = mQqWeiboProxy.getExpireIn();
String openID = mQqWeiboProxy.getOpenID();
String openKey = mQqWeiboProxy.getOpenKey();
log.e("access_token = " + access_token + "\nexpires_in = " + expires_in +
"\nopenID = " + openID + "\nopenKey = " + openKey);
AuthoSharePreference.putToken(mContext, access_token);
AuthoSharePreference.putExpires(mContext, expires_in);
AuthoSharePreference.putOpenID(mContext, openID);
AuthoSharePreference.putOpenKey(mContext, openKey);
setResult(RESULT_OK);
finish();
}else{
Toast.makeText(OAuthV2WebViewActivity.this, "Autho Fail...", Toast.LENGTH_SHORT).show();
}
view.destroyDrawingCache();
view.destroy();
}
super.onPageStarted(view, url, favicon);
}
@Override
public void onPageFinished(WebView view, String url) {
// TODO Auto-generated method stub
hideProgress();
super.onPageFinished(view, url);
}
/*
* TODO Android2.2及以上版本才能使用该方法
* 目前https://open.t.qq.com中存在http资源会引起sslerror,待网站修正后可去掉该方法
*/
public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
if ((null != view.getUrl()) && (view.getUrl().startsWith("https://open.t.qq.com"))) {
handler.proceed();// 接受证书
} else {
handler.cancel(); // 默认的处理方式,WebView变成空白页
}
// handleMessage(Message msg); 其他处理
}
}
}
boolean ret = mQqWeiboProxy.parseAccessTokenAndOpenId(responseData);
用于解析url得到各项值
public boolean parseAccessTokenAndOpenId(String data)
{
if (data != null)
{
return OAuthV2Client.parseAccessTokenAndOpenId(data, mAuthV2);
}
return false;
}
然后将其存入数据库
String access_token = mQqWeiboProxy.getAccessToken();
String expires_in = mQqWeiboProxy.getExpireIn();
String openID = mQqWeiboProxy.getOpenID();
String openKey = mQqWeiboProxy.getOpenKey();
log.e("access_token = " + access_token + "\nexpires_in = " + expires_in +
"\nopenID = " + openID + "\nopenKey = " + openKey);
AuthoSharePreference.putToken(mContext, access_token);
AuthoSharePreference.putExpires(mContext, expires_in);
AuthoSharePreference.putOpenID(mContext, openID);
AuthoSharePreference.putOpenKey(mContext, openKey);
在测试微博API界面调用如下:
public class TestAPIActivity extends Activity implements OnClickListener{
private final CommonLog log = LogFactory.createLog();
private Button mBtnGetUserinfo;
private Button mBtnSendWeibo;
private TextView mTvInfo;
private QQWeiboProxy mQqWeiboProxy;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.test_layout);
initView();
initData();
}
public void initView()
{
mBtnGetUserinfo = (Button) findViewById(R.id.btn_getuser);
mBtnGetUserinfo.setOnClickListener(this);
mBtnSendWeibo = (Button) findViewById(R.id.btn_sendweibo);
mBtnSendWeibo.setOnClickListener(this);
mTvInfo = (TextView) findViewById(R.id.tv_info);
}
public void initData()
{
mQqWeiboProxy = QQWeiboProxy.getInstance();
}
private void showInfo(String str)
{
if (str != null)
{
mTvInfo.setText(str);
}else{
mTvInfo.setText("null");
}
}
@Override
public void onClick(View view) {
// TODO Auto-generated method stub
switch(view.getId())
{
case R.id.btn_getuser:
getUser();
break;
case R.id.btn_sendweibo:
sendWeibo();
break;
}
}
private void getUser()
{
String jString = mQqWeiboProxy.getUserInfo();
showInfo(jString);
}
private void sendWeibo()
{
String jString = mQqWeiboProxy.sendWeibo("geniuseoe2012");
showInfo(jString);
}
QQWeiboProxy是对SDK的封装类
public class QQWeiboProxy {
/*
* 请将以下三个参数替换成自己的应用值
*/
public final static String CONSUMER_KEY = ""; // appkey
public final static String CONSUMER_SECRET = ""; // secret
public final static String REDIRECT_URL = ""; // url回调地址
private final CommonLog log = LogFactory.createLog();
private final static String FORMAT = "json";
private final static String CLIENT_IP = "127.0.0.1";
private OAuthV2 mAuthV2;
private static QQWeiboProxy mWeiboManager;
public static synchronized QQWeiboProxy getInstance()
{
if (mWeiboManager == null)
{
mWeiboManager = new QQWeiboProxy();
}
return mWeiboManager;
}
private QQWeiboProxy()
{
mAuthV2 = new OAuthV2(REDIRECT_URL);
mAuthV2.setClientId(CONSUMER_KEY);
mAuthV2.setClientSecret(CONSUMER_SECRET);
}
public String getRedictUrl()
{
return REDIRECT_URL;
}
public String getAppKey()
{
return CONSUMER_KEY;
}
// 获得AUTHO认证URL地址
public String getAuthoUrl()
{
String urlStr = OAuthV2Client.generateImplicitGrantUrl(mAuthV2);
return urlStr;
}
public void setAccesToakenString(String token)
{
if (token != null)
{
mAuthV2.setAccessToken(token);
}
}
public void setOpenid(String openID)
{
if (openID != null)
{
mAuthV2.setOpenid(openID);
}
}
public void setOpenKey(String openKey)
{
if (openKey != null)
{
mAuthV2.setOpenkey(openKey);
}
}
public void setExpireIn(String expireIn)
{
if (expireIn != null)
{
mAuthV2.setExpiresIn(expireIn);
}
}
public boolean parseAccessTokenAndOpenId(String data)
{
if (data != null)
{
return OAuthV2Client.parseAccessTokenAndOpenId(data, mAuthV2);
}
return false;
}
public String getAccessToken()
{
return mAuthV2.getAccessToken();
}
public String getOpenID()
{
return mAuthV2.getOpenid();
}
public String getOpenKey()
{
return mAuthV2.getOpenkey();
}
public String getExpireIn()
{
return mAuthV2.getExpiresIn();
}
// 获取用户资料
public String getUserInfo()
{
String reString = null;
UserAPI mUserAPI = new UserAPI(OAuthConstants.OAUTH_VERSION_2_A);
try {
reString = mUserAPI.info(mAuthV2, FORMAT);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
mUserAPI.shutdownConnection();
return reString;
}
// 发送微博
public String sendWeibo(String content)
{
String rString = null;
TAPI mTapi = new TAPI(OAuthConstants.OAUTH_VERSION_2_A);
try {
rString = mTapi.add(mAuthV2, FORMAT, content, CLIENT_IP);
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
mTapi.shutdownConnection();
return rString;
}
}
测试下发微博,调用得到的json串显示在屏幕上,登陆微博查看发送成功!
下面简单介绍下工程代码:
com.mobile.tencent.weibo.sdk包是官方SDK源码拷贝过来的(作了部分裁剪)
com.mobile.tencent.weibo.sdk.proxy里除了QQWeiboProxy其它的也是SDK的源码,那些API后缀类已经封装了很多接口了
唯一额外需要导入的就一个httpmime-4.1.3jar包
这样童鞋们就可以很方便滴将代码COPY走而应用到自己的项目,当然也可以选择将那些代码重新打一个jar包导入工程
差不多就这样啦,附上工程链接:
http://download.csdn.net/detail/geniuseoe2012/4565412
最后大家记得要更换自己的应用KEY值
以后会陆续更新完整的客户端源码,敬请留意窝的博客更新