新浪微博Oauth2.0授权 获取Access Token以及API的使用

因为毕业设计要做微博数据采集,现在微博数据获取主要有两种方式:基于官方API和基于网络爬虫,这几天看下如何使用官方API的方式,比较麻烦的是oauth2验证,今天看到一篇帖子,实践了API的使用方式,转载下来看看。

转载至:http://blog.csdn.net/xyw_blog/article/details/8907918

使用新浪微博API的前提是需要到新浪微博开放平台注册一个应用,获得App Key和App Secret,然后再根据这两个获取Access Token。下面详细介绍如何获取Access Token以及如何使用新浪微博提供的API。

一、获取Access Token

1、进入新浪微博开放平台,进入应用开发,选择创建应用,这里我选择的是“网页应用”


2、填写应用的基本信息

可以随便填写,点击“创建”,就可以创建成功!

创建成功后,可以查看应用的信息。主要需要的是App Key和App Secret。


3、添加授权回调页

选择刚刚创建的应用,进入到应用信息,选择高级信息,添加授权回调页。

这个一定要添加,如果没有授权回调页,是无法获取到Access Token 的,而且必须保证回调页的网址时可以访问的。


4、获取新浪微博SDK包

在新浪微博开放平台,选择文档->资源下载->SDK下载,我选择Java SDK的版本。下载完成后,解压缩,将项目导入到Eclipse中。

可以查看一下文档:readme.txt,内容为:

[plain]  view plain  copy
 print ?
  1. 请先填写相关配置:在Config.properties里  
  2. client_ID :appkey                             
  3. client_SERCRET :app_secret  
  4. redirect_URI : 回调地址  
即运行项目的前提需要进行配置。

5、配置SDK开发包

打开Config.properties文件(在src目录下)

[plain]  view plain  copy
 print ?
  1. client_ID =   
  2. client_SERCRET =   
  3. redirect_URI =   
  4. baseURL=https://api.weibo.com/2/  
  5. accessTokenURL=https://api.weibo.com/oauth2/access_token  
  6. authorizeURL=https://api.weibo.com/oauth2/authorize  
  7. rmURL=https://rm.api.weibo.com/2/  
需要你填写client_ID、client_SERCRET、redirect_URI ,这一定要与你的应用相对应。格式和下方的相同。不要加双引号,不要在结尾加分号。

6、获取Access Token

打开example资源文件夹下,weibo4j.examples.oauth2文件夹下的OAuth4Code.java

将代码:

[plain]  view plain  copy
 print ?
  1. BareBonesBrowserLaunch.openURL(oauth.authorize("code",args[1],args[2]));  
  2. System.out.println(oauth.authorize("code",args[1],args[2]));  
修改为:

[plain]  view plain  copy
 print ?
  1. BareBonesBrowserLaunch.openURL(oauth.authorize("code","",""));  
  2. System.out.println(oauth.authorize("code","", ""));  
即除去args参数。

然后选择run as Java Application,打开了浏览器,即打开的是你填写的回调地址,注意查看此时的url,最后一部分是code=XXXXXXXXXXXXXXXXXXXXX。复制这个code的值。查看Eclipse的控制台窗口:

 
输入刚刚获得的code值,点击回车。

这时已经获得了access_token值和uid的值,现在你就可以使用access_token来运行example中的程序了。注意,access_token的值有一定的时效性,access_token失效后需要重新申请一下,即重复第6步,每次access_token的值是不会改变的。

二、运行example实例程序

我选择的是weibo4j.examples.timeline中的ShowStatus.java。将access_token换成刚才得到的值,id指的是微博的ID,运行,即可得到有关微博的信息以及用户的信息。注意,这里的第二个参数即id一定是具体某条微博的id,而不是uid!!!


其他的程序也是相同的道理。


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
OAuth2.0 客户端获取 token 通常有以下两种方式: 1. 授权码模式(Authorization Code Grant) 授权码模式是 OAuth2.0 中最常用的一种授权方式,它允许客户端间接获取访问令牌。在授权码模式中,客户端需要引导用户跳转到认证服务器,用户在认证服务器上登录并授权给客户端访问令牌,然后认证服务器将授权码返回给客户端,客户端使用授权码向认证服务器请求访问令牌。授权码模式通常用于 Web 应用程序和移动应用程序等场景,它可以在客户端和认证服务器之间建立安全的通信通道。 2. 密码模式(Password Grant) 密码模式是 OAuth2.0 中一种不太安全的授权方式,它允许客户端直接通过用户的用户名和密码获取访问令牌。在密码模式中,客户端需要向认证服务器发送用户的用户名和密码以及客户端的 ID 和密钥等信息,认证服务器验证用户的身份后返回访问令牌给客户端。密码模式通常用于测试和开发等场景,不建议在生产环境中使用。 下面是一个使用 Java 语言实现 OAuth2.0 客户端获取访问令牌的示例代码(使用 Spring Security OAuth2 客户端库): ```java import org.springframework.security.oauth2.client.OAuth2RestTemplate; import org.springframework.security.oauth2.client.token.grant.password.ResourceOwnerPasswordResourceDetails; // 创建 OAuth2RestTemplate ResourceOwnerPasswordResourceDetails resourceDetails = new ResourceOwnerPasswordResourceDetails(); resourceDetails.setAccessTokenUri("https://oauth2.example.com/token"); resourceDetails.setClientId("your_client_id"); resourceDetails.setClientSecret("your_client_secret"); resourceDetails.setUsername("your_username"); resourceDetails.setPassword("your_password"); OAuth2RestTemplate restTemplate = new OAuth2RestTemplate(resourceDetails); // 使用 OAuth2RestTemplate 发送请求 String result = restTemplate.getForObject("https://api.example.com/resource", String.class); ``` 在上面的代码中,我们首先创建了一个 ResourceOwnerPasswordResourceDetails 对象,并设置了访问令牌 URI、客户端 ID、客户端密钥、用户名和密码等参数。然后,我们使用这些参数创建了一个 OAuth2RestTemplate 对象,并使用它发送了一个请求。需要注意的是,使用密码模式获取访问令牌需要在 OAuth2 服务器上启用密码模式,并且客户端需要被授权使用密码模式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值