锁定老帖子 主题:新浪微博---开放平台的使用01
精华帖 (0) :: 良好帖 (0) :: 新手帖 (5) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2011-06-05
现在有很多的开放平台,可以供第三方来基于这些开放平台开发应用程序,最近在做新浪微博的一个小例子,刚刚入门,高手勿拍砖! 1、http://open.weibo.com这个是新浪的开放平台,里面有SDK,有开发文档等等
2、下载SDK,我暂时先下载了一个JAVA的SDK来实验一下,具体地址:http://open.weibo.com/wiki/index.php/SDK#Java_SDK
3、将其解压到eclipse的workspace里面,然后导入到eclipse
4、开发第三方应用程序,需要创建一下应用,之后你会得到一个
Key App Key: 1211****** App Secret: d6b*****************************
5、一开始是找到的是weibo4j.Weibo.java、weibo4j.examples.statues.UpdateStatus.java文件,于是在UpdateStatus.java里修改了一下Key和Secret的值,当然如果用默认的,好像是不出错的,但是我用了一下自己的,却出错了,什么错误呢?
weibo4j.WeiboException: 403:The request is understood, but it has been refused. An accompanying error message will explain why. {"request":"/statuses/update.json","error_code":"403","error":"40320:Error: basic auth forbidden !"} at weibo4j.http.HttpClient.httpRequest(HttpClient.java:669) at weibo4j.http.HttpClient.httpRequest(HttpClient.java:611) at weibo4j.http.HttpClient.post(HttpClient.java:435) at weibo4j.Weibo.updateStatus(Weibo.java:1276) at weibo4j.examples.statuses.UpdateStatus.main(UpdateStatus.java:28) 网上说的是:将自己添加为测试用户 ①登录开放平台,我的应用--编辑应用属性---测试用户UID ②这个UID就是你注册新浪微博的时候,分配给你的一串类似于QQ号的东西,可以到“我的微博” ,上面会有你的名字和微博的ID,这串数字就是UID ③将UID放到输入框里,就会将你自己添加为测试用户
看到basic auth认证机制不能用了,于是我将 Weibo weibo = getWeibo(false,args);里面的false改为true,让它使用OAuth认证,但是可能是由于我太菜了,运行后还是有问题,再次如果有那个朋友知道的话帮个忙哈
args = new String[]{"xxxxx@.sina.cn","*******"}; Weibo weibo = getWeibo(false,args); Status status = weibo.updateStatus("心语互动测试成功!"); System.out.println(status.getId() + " : "+ status.getText()+" "+status.getCreatedAt()); 上面是UpdateStatus里面的代码,下面是运行后的错误
weibo4j.WeiboException: 403:The request is understood, but it has been refused. An accompanying error message will explain why. {"request":"/statuses/update.json","error_code":"403","error":"40320:Error: basic auth forbidden !"} at weibo4j.http.HttpClient.httpRequest(HttpClient.java:669) at weibo4j.http.HttpClient.httpRequest(HttpClient.java:611) at weibo4j.http.HttpClient.post(HttpClient.java:435) at weibo4j.Weibo.updateStatus(Weibo.java:1276) at weibo4j.examples.statuses.UpdateStatus.main(UpdateStatus.java:28) 即使查了错误代码,还是不知道到底是哪里错了
6、后来我看了一下readme.txt说明文档,想用不需要认证的OAuth来试试,于是按照它的说法:
OAuth桌面应用访问 步骤: 1> 在weibo4j.examples.OAuthUpdate 访问认证的URL,得到pin 2> 在weibo4j.examples.OAuthUpdate 输入pin,然后得到AccessToken 3> 即可访问用户的微博,参考:weibo4j.examples.OAuthUpdateTwo
weibo4j.examples.OAuthUpdateTwo 尝试了一下,运行后控制台下会有个链接,点击这个链接,会得到一个pin:350576 在控制台输入pin后,得到了
Access token: f520d1efb5532e6daf************** Access token secret: ddb5f6990b66579fe4**************
7、然后将Access token和Access token secret放入weibo4j.examples.OAuthUpdateTwo中
/* * 此处需要填写AccessToken的key和Secret,可以从OAuthUpdate的执行结果中拷贝过来 */ // weibo.setToken("AccessToken", "AccessTokenSecret"); weibo.setToken("f520d1efb5532e6daf**************", "ddb5f6990b66579fe4**************"); 8、下面这条语句是更新状态的语句,你可以输入你想说的
Status status = weibo.updateStatus("你好吗?");
9、然后还要将你的用户名和密码加入到里面,注意红色部分
args = new String[]{"*******@sina.cn","*******"};
if (args.length < 2) {
System.out.println(
"Usage: java weibo4j.examples.OAuthUpdateTwo token tokenSecret");
System.exit( -1);
}
10、运行JAVA程序,然后更新博客,你会看到状态更新了
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2011-06-09
9、然后还要将你的用户名和密码加入到里面,注意红色部分
没有意义吧。。。拿到 Access token: f520d1efb5532e6daf************** Access token secret: ddb5f6990b66579fe4************** 就可以了。。 |
|
返回顶楼 | |
发表时间:2011-06-09
kala888 写道 9、然后还要将你的用户名和密码加入到里面,注意红色部分
没有意义吧。。。拿到 Access token: f520d1efb5532e6daf************** Access token secret: ddb5f6990b66579fe4************** 就可以了。。 但是没有加用户名和密码会报错,当时我也是按照说明文档来做的,后来加上了用户名和密码后,可以运行了,具体原因我还在研究中... |
|
返回顶楼 | |
发表时间:2011-06-09
我做过一个小应用,只要有Access token和Access token secret就可以了,不要用户名密码
另外我想问个相关的问题 类似开放平台的认证都用到了request token 和 access token 用request token换取access token的意义何在,为什么不能直接拿到access token 还有request token 和 access token都各自对应一个secret 有人能解释下原理吗 http://open.weibo.com/wiki/index.php/Oauth |
|
返回顶楼 | |
发表时间:2011-06-09
最后修改:2011-06-09
oauth1.0的协议就是这样的,出于安全考虑
参考:http://tools.ietf.org/html/rfc5849 |
|
返回顶楼 | |
发表时间:2011-06-10
ewong 写道 我做过一个小应用,只要有Access token和Access token secret就可以了,不要用户名密码
另外我想问个相关的问题 类似开放平台的认证都用到了request token 和 access token 用request token换取access token的意义何在,为什么不能直接拿到access token 还有request token 和 access token都各自对应一个secret 有人能解释下原理吗 http://open.weibo.com/wiki/index.php/Oauth 用request_token是因为request_token被授权后,会暴露在url中, 被认为是不安全的,因此被设计为一次性使用,换取access_token后即作废。 access_token全程是在后台进行交互的,被认为是安全的。 secret,是为了确保token所有权的签名密钥。 还有个timestamp和nonce, 是防止重放攻击的 |
|
返回顶楼 | |
发表时间:2011-06-13
新浪微博公示说六月份开始停止基础身份验证的服务,只提供OAuth的认证方式
|
|
返回顶楼 | |
发表时间:2011-06-13
每个平台,API不一样,头痛。
|
|
返回顶楼 | |
浏览 8277 次