接上篇博文提到了
android新浪微博Oauth2.0认证以及登录
http://blog.csdn.net/geniuseoe2012/article/details/7727564
也提到了写SDK的这家伙很坑爹的把界面元素也添到了SDK里面
而我们则希望SDK提供的是纯接口的东东
之前看到网上不少关于webview实现新浪微博认证,思路都是通过WebView显示的html代码然后从中提取出授权码,不过那样界面会跳转到授权码显示页面,界面看起来不是很和谐,而我们直接使用SDK里的那种方式就可以很方便的实现我们想要的效果
为此在下特意研究了下SDK里认证界面的具体实现,然后将其中的代码提取出来,仿其实现方式用我们自己的webview来实现微博的认证过程,这样我们就不必再依赖SDK工程而可以直接将SRC打成jar包导入了,下面先看工程目录图:
Com.weibo.net这个包就是把SDK里的代码copy过来,然后把一些不相干的类给干掉了,同时屏蔽掉一些接口,本例没有把它们打成jar包,为的是方便大家看到源码
同时SDK里的源码有个小错误:
就是AsyncWeiboRunner类下的request方法
public void request(final Context context,
final String url,
final WeiboParameters params,
final String httpMethod,
final RequestListener listener){
new Thread(){
@Override public void run() {
try {
String resp = mWeibo.request(context, url, params, httpMethod, mWeibo.getAccessToken());
listener.onComplete(resp);
} catch (WeiboException e) {
listener.onError(e);
}
}
}.run();
}
尼玛直接run难怪会阻塞UI线程,改成start就OK了。
下面着重讲讲webview这个页面认证的实现原理
且看WeiboWebViewClient这个类
private class WeiboWebViewClient extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
MyDebug.print("WeiboWebViewClient", "shouldOverrideUrlLoading url = " + url);
showProgress();
view.loadUrl(url);
return super.shouldOverrideUrlLoading(view, url);
}
@Override
public void onReceivedError(WebView view, int errorCode, String description,
String failingUrl) {
MyDebug.printErr("WeiboWebViewClient", "onReceivedError failingUrl = " + failingUrl);
super.onReceivedError(view, errorCode, description, failingUrl);
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
MyDebug.print("WeiboWebViewClient", "onPageStarted url = " + url + "\nthreadid = " +
Thread.currentThread().getId());
showProgress();
if (url.startsWith(mWeiboManager.getRedictUrl())) {
handleRedirectUrl(view, url, WebViewActivity.this);
view.stopLoading();
return;
}
super.onPageStarted(view, url, favicon);
}
@Override
public void onPageFinished(WebView view, String url) {
MyDebug.print("WeiboWebViewClient", "onPageFinished url = " + url);
hideProgress();
super.onPageFinished(view, url);
}
private boolean handleRedirectUrl(WebView view, String url, IWeiboClientListener listener)
{
Bundle values = Utility.parseUrl(url);
String error = values.getString("error");
String error_code = values.getString("error_code");
MyDebug.print("handleRedirectUrl", "error = " + error + "\n error_code = " + error_code);
if (error == null && error_code == null)
{
listener.onComplete(values);
}else if (error.equals("access_denied"))
{
listener.onCancel();
}else{
WeiboException weiboException = new WeiboException(error, Integer.parseInt(error_code));
listener.onWeiboException(weiboException);
}
return false;
}
}
下面这个是关键:
if (url.startsWith(mWeiboManager.getRedictUrl())) {
handleRedirectUrl(view, url, WebViewActivity.this);
view.stopLoading();
return;
}
也就是我们进入授权页面点击授权的时候,页面最终会去载入我们先前传入的URL回调地址(该回调地址作为前缀),此时我们只要从该URL里去解析我们想要的东西即可
如何解析URL在sdk里有提供相应方法,即Utility.parseUrl(url);在handleRedirectUrl里根据解析得到的结果调用监听器相应接口即可,我们再看看监听器onComplete里的实现
public void onComplete(Bundle values) {
// TODO Auto-generated method stub
CookieSyncManager.getInstance().sync();
String access_token = values.getString("access_token");
String expires_in = values.getString("expires_in");
String remind_in = values.getString("remind_in");
String uid = values.getString("uid");
MyDebug.print("onComplete", "access_token = " + access_token +
"\nexpires_in = " + expires_in);
AuthoSharePreference.putToken(this, access_token);
AuthoSharePreference.putExpires(this, expires_in);
AuthoSharePreference.putRemind(this, remind_in);
AuthoSharePreference.putUid(this, uid);
AccessToken accessToken = new AccessToken(access_token, WeiboConstParam.CONSUMER_SECRET);
mWeiboManager.setAccessToaken(accessToken);
setResult(RESULT_OK);
finish();
}
怎么样,是不是跟官方的那个例子很接近了,拿到access_token我们就可以为所欲为了
截图就不贴了,跟前篇博文的效果差不多,只不过认证页面放在了activity里而不在一个dialog而已
下面附上源码工程:
http://download.csdn.net/detail/geniuseoe2012/4441971
老规矩,WeiboConstParam.java里的key值等等参数修改成自己的值就可以了
public interface WeiboConstParam {
String CONSUMER_KEY = "-----------"; // appkey
String CONSUMER_SECRET = "------------"; // secret
String REDIRECT_URL = "---------------"; // url回调地址
}
本例发微博部分只能发纯文本,以后再教大家如何使用更多微博API,
敬请留意窝的博客更新
分享到:
相关推荐
RT,使用WebView实现新浪微博Oauth2.0认证,非截取html代码获取验证码 界面跳转无副作用
android 腾讯微博Oauth2.0认证以及自定义webview认证
自己写的使用WebView授权DEMO 与上一版相比,该demo取消使用safari授权、取消使用asi进行http访问;同时保留了aes加密模块;增加了腾讯微博的授权,分享微博功能
oauth2.0授权界面,大致流程图: 前提准备: 在新浪开放平台申请appkey和appsecret:http://open.weibo.com/. 熟悉oauth2.0协议,相关知识:http://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html OAuth2的...
Android WebView 新浪微博自动登陆
通过winform使用httpclient客户端调用webApi接口,api使用oauth2.0权限控制,调用接口需要进行token获取认证、
Android版新浪、网易、腾讯、搜狐微博OAuth认证实例集,想更多了解OAuth认证的朋友,请下载java源码包,在示例中完整解析了OAuth认证的过程:定义URL编码方式,请求url,得到注册应用后服务商提供的key和secret,...
Android新浪微博,通过WebView来截取授权验证码 ~~~~ Android新浪微博,通过WebView来截取授权验证码 ~~~~
Android简单基于WebView的OAuth身份验证库
仿新浪微博Android客户端主界面的源码。
android使用webView实现java程序与js脚本的相互调用,
所谓SSO认证,通俗的一点讲就是,自己写的app需要使用新浪或腾讯微进行分享、发表微博等操作。如果用户的手机客户端安装了符合SSO认证的新浪、腾讯等微博客户端版本且已登录,则会自动启动新浪、腾讯等微博客户端...
// 20_帅哥no微博 // // Created by beyond on 14-8-5. // Copyright (c) 2014年 com.beyond. All rights reserved. // 授权控制器,仅运行一次,取得了当前用户的access_token和uid之后,存档,切换窗口的主控制器 #...
仿新浪微博Android客户端主界面的源码。
Android APP使用WebView调用H5页面完成摄像头扫描二维码 项目使用Android Studio,打开项目可以直接运行,用过的都说好:)
工具使用WebView从您的golang http服务器构建Android应用
在android的webview中实现websocket通信
Android-X5WebView基本封装和使用 通过OkHttp拦截器、自定义CookieJar有效完成客户端与H5端的Cookie同步管理 监听WebView的加载进度 滚动条的设置(隐藏或者显示,内侧显示还是外侧显示) 优化X5WebView的预加载问题...
本资源配套本人的博客文章《Android开发】Android Studio中进行简单的WebView构建浏览器开发1》和《Android开发】Android Studio中进行简单的WebView构建浏览器开发2》进行使用,实现了基本的浏览器功能:包括:输入...
Android 基于x5Webview 浏览文件 office文档 已测试Android11 功能实现