使用新浪微博开放平台api同步微博内容至自己网站(修改SDK包里面Weibo.java类的App和AppSecret)

优采云 发布时间: 2022-04-05 08:22

  使用新浪微博开放平台api同步微博内容至自己网站(修改SDK包里面Weibo.java类的App和AppSecret)

  使用新浪微博开放平台的API,首先要获取新浪分配的App key和App Secret。以下是我创建应用后sina分配的App key和App Secret(这个要保密)。

  

  然后下载微博SDK,我用Java的weibo4j。目前提供以下语言版本:

  

  将SDK包中Weibo.java类的App Key和App Secret修改为刚刚获取的App Key和App Secret,如下图所示:

  

  完成后,就可以根据提供的Demo开始编写代码了。如下:

  WebOAuth.java用于初始化Weibo.java类所需的App Key和App Secret,并提供getRequestToken()和gettAccessToken()方法获取Request Token和Access Token。所需的参数显示在代码中。此外,还提供了一个发布文本微博的方法update()。

  

<p>package weibo4j.examples; 

   

  import weibo4j.Status; 

  import weibo4j.Weibo; 

  import weibo4j.WeiboException; 

  import weibo4j.http.AccessToken; 

  import weibo4j.http.RequestToken; 

  import java.io.UnsupportedEncodingException; 

   

  // Web 方式认证 

  public class WebOAuth { 

      private Weibo weibo; 

   

      public WebOAuth(){       

          // 准备好Consumer Key、Consumer Secret 

          // 对应于新浪微博应用就是申请到的 App key 和 Secret key 

          System.setProperty("weibo4j.oauth.consumerKey", Weibo.CONSUMER_KEY); 

          System.setProperty("weibo4j.oauth.consumerSecret", Weibo.CONSUMER_SECRET); 

          weibo = new Weibo(); 

      } 

   

      // 根据传入的 callback_url 获取 request token 

      public RequestToken getRequestToken(String backUrl) { 

          try { 

              // 指定 callback_url 并获得 request token 

              RequestToken requestToken = weibo.getOAuthRequestToken(backUrl); 

   

              System.out.println("Request token: " + requestToken.getToken()); 

              System.out.println("Request token secret: " + requestToken.getTokenSecret()); 

   

              return requestToken; 

          } catch (Exception e) { 

              System.out.println("获取Request token发生异常!"); 

              e.printStackTrace(); 

              return null; 

          } 

      } 

   

      // 根据传入的 request token 和 verifier 获取 access token 

      public AccessToken gettAccessToken(RequestToken requestToken, String verifier) { 

          try {            

              AccessToken accessToken = weibo.getOAuthAccessToken(requestToken 

                      .getToken(), requestToken.getTokenSecret(), verifier); 

               

              System.out.println("Access token: " + accessToken.getToken()); 

              System.out.println("Access token secret: " + accessToken.getTokenSecret()); 

   

              return accessToken; 

          } catch (Exception e) { 

              System.out.println("获取Access token发生异常!"); 

              e.printStackTrace(); 

              return null; 

          } 

      } 

   

      // 根据传入的 Access Token 和内容发表微博 

      public void update(AccessToken access, String content) { 

          try { 

              weibo.setToken(access.getToken(), access.getTokenSecret()); 

              content = new String(content.getBytes("GBK"), "UTF-8"); 

              Status status = weibo.updateStatus(content); 

              System.out.println("成功发表微博:" + status.getText() + "."); 

          } catch (UnsupportedEncodingException e) { 

              System.out.println("微博内容转编码发生异常!"); 

              e.printStackTrace(); 

          } catch (WeiboException e) { 

              System.out.println("发表微博发生异常!"); 

              e.printStackTrace(); 

          } 

      } 

  } 

</p>

  request.jsp,用于提供callback_url(这里我们自定义为下面的callback.jsp),获取RequestToken后,将RequestToken保存在Session中,并将页面重定向到callback.jsp进行验证,授权。

  

<p> 

   

   

   

   

   

   

   

          请点击进行Web方式的OAuth认证!</a>    

   

</p>

  callback.jsp,在上一步重定向后,会在callback_url后面附加oauth_verifier参数。这时候我们根据Session中保存的RequestToken和获取到的oauth_verifier参数申请AccessToken。获取到AccessToken后,我们将页面重定向到writeWeibo.html,即写微博的页面。

  

<p> 

   

   

   

   

   

</p>

  writeWeibo.html,一个很简单的HTML文件。

  

<p> 

      发布sina微博 

       

              

              请在这里写上140字符以内的文本:</br> 

              测试新浪微博!</br> 

               

              </br> 

           

       

   

</p>

  

<p> 

   

   

   

   

   

</p>

  在运行之前,我们需要准备好Tomcat,并将上述源文件放到正确的目录下。另外SDK包中收录的commons-httpclient-3.1.jar包也要加到\WEB-INF\lib目录下,还有我编译打包的weibo4j.jar (里面是新浪微博开放平台的具体Java实现)。

  运行Tomcat,在浏览器中访问request.jsp页面,如下图:

  

  点击链接,如下图(注意地址栏的变化):

  

  地址栏中的网址如下:

  ://localhost:8080/sinaweibo/callback.jsp

  填写具体有效的新浪微博账号、密码和授权。以下是我用于测试和授权的微博账号填写的结果:

  

  地址栏中的网址如下:

  :8080/sinaweibo/writeWeibo.html

  点击“发布”,如下图:

  

  登录微博查看,如下图:

  

  查看此帐号授权的应用列表:

  

  到此为止,关于使用新浪微博开放平台发布微博的OAuth方式大概就是这个过程了。

  总结:

  1、其实还有很多细节没办法讲。我也试了很多次,一点点找到问题,明白问题,然后解决问题;

  2、如果我们登录新浪微博的账号信息cookie已经保存在浏览器中,那么授权时就不需要输入账号信息了,当然也可以不修改用于授权的当前账户;

  3、还有一些信息是在控制台输入的,比如Token、URL、服务器返回信息,截图中没有给出。

0 个评论

要回复文章请先登录注册


官方客服QQ群

微信人工客服

QQ人工客服


线