http://www.iteye.com/topic/905090
最近看了一下新浪围脖的Oauth消息发送的方式,整理一下。
新浪微博开放平台上对Oauth的授权与发送流程介绍的很清楚 http://open.t.sina.com.cn/wiki/index.php/Oauth 。有兴趣的可以自己去研究。
本文通过java代码直观的将上面的流程描述一下。
欲善其事,先利其器。先下载一下围脖java的SDK ,这个SDK太懒了,里面是源码,直接开源了,哈哈。
1、先去 微博开放平台 创建一个应用 ,应用好了,你会得到一个应用的App Key,和一个App Secret。我们会用这两个数据换取Oauth认证的Request token.
好了,代码开始了。
2、设置App Key和App Secret的值,下面是偶的应用的。
- System.setProperty("weibo4j.oauth.consumerKey", "4212139527");
- System.setProperty("weibo4j.oauth.consumerSecret","e20e613826de4d084b279a0236c167de");
System.setProperty("weibo4j.oauth.consumerKey", "4212139527");
System.setProperty("weibo4j.oauth.consumerSecret","e20e613826de4d084b279a0236c167de");
3、new一个新浪微博对象 Weibo weibo = new Weibo(); 获取Request token。
- requestToken = weibo.getOAuthRequestToken(backUrl);
requestToken = weibo.getOAuthRequestToken(backUrl);
4、现在已经有request token,我们需要换取access token,access token是和围脖的帐号关联在一起的,在换取access token之前,我们需要对用户对你的这个应用通过Oauth访问时进行授权。
授权的链接如下,后面的红色部分,就是第3步得到的request token
http://api.t.sina.com.cn/oauth/authorize?oauth_token=e54abbaff178411f7c1aeda9736376fc
打开授权链接,对应用完成授权,会自动跳转到第3步指定的callback url,并将oauth_verifier一起返回。形如下面的形式:http://www.iteye.com /?oauth_token=e54abbaff178411f7c1aeda9736376fc&oauth_verifier= 637479
5、真正取得Access Token
- accessToken = weibo.getOAuthAccessToken(
- requestToken.getToken(), requestToken.getTokenSecret(),
- verifier);
accessToken = weibo.getOAuthAccessToken(
requestToken.getToken(), requestToken.getTokenSecret(),
verifier);
6、Ok,将此Access Token保存下来,以后就可以直接通过此Token直接向新浪围脖发消息了。
7、发一条文本消息
- weibo.updateStatus(message);
weibo.updateStatus(message);
如果用下面的接口发图片的,需要注意一下,ImageItem前面的参数只能是pic,而且发的消息内容必须URLEncoder一下。这接口设计的……真土!
- item = new ImageItem("pic", bytes);
- weibo.uploadStatus(URLEncoder.encode("网络图片", "UTF-8"), item);
item = new ImageItem("pic", bytes);
weibo.uploadStatus(URLEncoder.encode("网络图片", "UTF-8"), item);
好了,完整的测试代码放到附件里,自己可以运行一下。
对应用授权需要将程序输出的授权地址,手动拷贝到浏览器。完成后,需要将oauth_verifier的值从终端里告诉程序。然后就可以通过终端发消息了。