sina微博開放平臺中使用OAuth驗證並發表微博

 看來微博在中國又有一次不可忽略的發展了,因爲昨天有這麼一個新聞“中國首屆微博開發者大會”,官網如下圖:

 

要使用sina微博開放平臺的API,應先獲取sina分配的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,並提供獲取Request Token Access Token 的方法getRequestToken()gettAccessToken(),其所需參數如代碼所示。另外,還提供了發佈一個文本微博的方法update()

  1. package weibo4j.examples; 
  2.  
  3. import weibo4j.Status; 
  4. import weibo4j.Weibo; 
  5. import weibo4j.WeiboException; 
  6. import weibo4j.http.AccessToken; 
  7. import weibo4j.http.RequestToken; 
  8. import java.io.UnsupportedEncodingException; 
  9.  
  10. // Web 方式認證 
  11. public class WebOAuth { 
  12.     private Weibo weibo; 
  13.  
  14.     public WebOAuth(){       
  15.         // 準備好Consumer Key、Consumer Secret 
  16.         // 對應於新浪微博應用就是申請到的 App key 和 Secret key 
  17.         System.setProperty("weibo4j.oauth.consumerKey", Weibo.CONSUMER_KEY); 
  18.         System.setProperty("weibo4j.oauth.consumerSecret", Weibo.CONSUMER_SECRET); 
  19.         weibo = new Weibo(); 
  20.     } 
  21.  
  22.     // 根據傳入的 callback_url 獲取 request token 
  23.     public RequestToken getRequestToken(String backUrl) { 
  24.         try { 
  25.             // 指定 callback_url 並獲得 request token 
  26.             RequestToken requestToken = weibo.getOAuthRequestToken(backUrl); 
  27.  
  28.             System.out.println("Request token: " + requestToken.getToken()); 
  29.             System.out.println("Request token secret: " + requestToken.getTokenSecret()); 
  30.  
  31.             return requestToken; 
  32.         } catch (Exception e) { 
  33.             System.out.println("獲取Request token發生異常!"); 
  34.             e.printStackTrace(); 
  35.             return null
  36.         } 
  37.     } 
  38.  
  39.     // 根據傳入的 request token 和 verifier 獲取 access token 
  40.     public AccessToken gettAccessToken(RequestToken requestToken, String verifier) { 
  41.         try {            
  42.             AccessToken accessToken = weibo.getOAuthAccessToken(requestToken 
  43.                     .getToken(), requestToken.getTokenSecret(), verifier); 
  44.              
  45.             System.out.println("Access token: " + accessToken.getToken()); 
  46.             System.out.println("Access token secret: " + accessToken.getTokenSecret()); 
  47.  
  48.             return accessToken; 
  49.         } catch (Exception e) { 
  50.             System.out.println("獲取Access token發生異常!"); 
  51.             e.printStackTrace(); 
  52.             return null
  53.         } 
  54.     } 
  55.  
  56.     // 根據傳入的 Access Token 和內容發表微博 
  57.     public void update(AccessToken access, String content) { 
  58.         try { 
  59.             weibo.setToken(access.getToken(), access.getTokenSecret()); 
  60.             content = new String(content.getBytes("GBK"), "UTF-8"); 
  61.             Status status = weibo.updateStatus(content); 
  62.             System.out.println("成功發表微博:" + status.getText() + "."); 
  63.         } catch (UnsupportedEncodingException e) { 
  64.             System.out.println("微博內容轉編碼發生異常!"); 
  65.             e.printStackTrace(); 
  66.         } catch (WeiboException e) { 
  67.             System.out.println("發表微博發生異常!"); 
  68.             e.printStackTrace(); 
  69.         } 
  70.     } 

request.jsp,用於提供 callback_url(這裏我們自定義爲下文中的callback.jsp),當獲取得到RequestToken之後,保存該RequestTokenSession中,並將頁面重定向到callback.jsp進行驗證、授權。

  1. <%@ page contentType="text/html;charset=utf-8" %> 
  2. <%@ page language="java" import="weibo4j.*" %> 
  3. <%@ page language="java" import="weibo4j.http.*" %> 
  4. <%@ page language="java" import="weibo4j.util.*" %> 
  5.  
  6. <jsp:useBean id="weboauth" scope="session" class="weibo4j.examples.WebOAuth" /> 
  7.  
  8. <% 
  9.     if("1".equals(request.getParameter("opt"))) 
  10.     { 
  11.         // 傳入callback_url 
  12.         String callback_url = "http://localhost:8080/sinaweibo/callback.jsp"
  13.         RequestToken requestToken = weboauth.getRequestToken(callback_url); 
  14.          
  15.         if(requestToken != null){ 
  16.             out.println(requestToken.getToken()); 
  17.             out.println(requestToken.getTokenSecret()); 
  18.             session.setAttribute("requestToken",requestToken); 
  19.  
  20.             String url = requestToken.getAuthorizationURL()+"&oauth_callback="+callback_url; 
  21.             System.out.println("AuthorizationURL:" + url); 
  22.  
  23.             //BareBonesBrowserLaunch.openURL(callback_url); 
  24.             //response.sendRedirect(requestToken.getAuthorizationURL()); 
  25.  
  26.             // 重定向到附加了callback_url回調地址的sina微博認證頁面 
  27.             response.sendRedirect(url); 
  28.         }else
  29.             out.println("request error"); 
  30.         } 
  31.     }else
  32. %> 
  33.         <a href="request.jsp?opt=1">請點擊進行Web方式的OAuth認證!</a>    
  34. <%  }   %> 

 

callback.jsp,在上一步中重定向之後,callback_url 後面會被附加了oauth_verifier參數,此時我們根據保存在 Session中的RequestToken和獲取到的oauth_verifier參數申請獲得AccessToken。一旦獲得AccessToken,我們再把頁面重定向到編寫微博的頁面writeWeibo.html

  1. <%@ page contentType="text/html;charset=utf-8" %> 
  2. <%@ page language="java" import="weibo4j.http.*" %> 
  3. <%@ page language="java" import="weibo4j.*" %> 
  4.  
  5. <jsp:useBean id="weboauth" scope="session" class="weibo4j.examples.WebOAuth" /> 
  6. <% 
  7.     // 獲得HTTP請求中的 oauth_verifier 參數 
  8.     String verifier=request.getParameter("oauth_verifier"); 
  9.  
  10.     out.println("oauth_verifier:"+verifier); 
  11.     System.out.println("oauth_verifier:"+verifier); 
  12.  
  13.     if(verifier != null){ 
  14.  
  15.         RequestToken requestToken = (RequestToken)session.getAttribute("requestToken"); 
  16.  
  17.         if(requestToken != null){ 
  18.  
  19.             AccessToken accessToken = weboauth.gettAccessToken(requestToken,verifier); 
  20.  
  21.             if(accessToken != null){ 
  22.                 try
  23.                     session.setAttribute("accessToken",accessToken);                     
  24.  
  25.                     out.println("5 秒後轉到 writeWeibo.html"); 
  26.                     Thread.sleep(5000); 
  27.                     response.sendRedirect("http://localhost:8080/sinaweibo/writeWeibo.html"); 
  28.  
  29.                 }catch(Exception e){ 
  30.                     e.printStackTrace(); 
  31.                 }                
  32.             }else
  33.                 out.println("access token request error"); 
  34.             }        
  35.         }else
  36.             out.println("request token session error"); 
  37.         } 
  38.     }else
  39.         out.println("verifier String error"); 
  40.     } 
  41. %> 

 

writeWeibo.html,很簡單的HTML文件。

  1. <html> 
  2.     <head><title>發佈sina微博</title></head> 
  3.     <body bgcolor="#d0d0d0" > 
  4.         <form action="updateWeibo.jsp" method="post">    
  5.             請在這裏寫上140字符以內的文本:</br> 
  6.             <textarea name="weiboText" rows="3" cols="30">測試新浪微博!</textarea></br> 
  7.             <input type="submit" value="發佈"> 
  8.             <input type="reset" value="清除"></br> 
  9.         </form> 
  10.     </body> 
  11. </html> 

 

updateWeibo.jsp,用於發表文本微博,即調用WebOAuth.java 中的update方法。

  1. <%@ page contentType="text/html;charset=utf-8" %> 
  2. <%@ page language="java" import="weibo4j.http.*" %> 
  3. <%@ page language="java" import="weibo4j.*" %> 
  4.  
  5. <jsp:useBean id="weboauth" scope="session" class="weibo4j.examples.WebOAuth" /> 
  6. <% 
  7.     AccessToken accessToken = (AccessToken)session.getAttribute("accessToken"); 
  8.     String weiboText = (String)request.getParameter("weiboText"); 
  9.  
  10.     // 連續發表同樣的微博內容會返回400錯誤 
  11.     weboauth.update(accessToken, weiboText); 
  12.     out.println("微博發表成功!"); 
  13. %> 

 

       運行之前我們要準備好 Tomcat ,並將上面的源文件放到正確的目錄中。此外,還應該在\WEB-INF\lib目錄下添加SDK包中帶有的commons-httpclient-3.1.jar 包,以及我自己編譯、打包後的weibo4j.jar(裏面是sina微博開放平臺中的具體Java實現)。

 

       運行Tomcat,在瀏覽器中訪問request.jsp 頁面,如下圖:

 

       點擊其中的鏈接,如下圖(注意地址欄的變化):

       其中地址欄的URL如下:

http://api.t.sina.com.cn/oauth/authorize?oauth_token=efda6f2499877d0e6d814f8c3d31a1d1&oauth_callback=http://localhost:8080/sinaweibo/callback.jsp

 

       填上具體有效的sina微博賬號、密碼並授權。以下是填上了我測試用的微博賬號並授權的結果:

       其中地址欄的URL如下:

http://localhost:8080/sinaweibo/writeWeibo.html

 

       點擊“發佈”,如下圖:

       登錄微博查看一下,如下圖:

      

       查看一下該賬號所授權的應用列表:

       至此,關於OAuth方式使用sina微博開放平臺來發布微博就大概是這個過程。

 

       小結:

1、其實還有好多細節沒能講到,我也是嘗試了好多次才一點點發現問題、理解問題、再到解決問題;

       2、如果瀏覽器中已經保存了我們登錄sina微博的賬號信息的Cookie,那麼在授權時不用輸入賬號信息,當然也可以修改不用當前賬號進行授權;

       3、還有控制檯輸入的一些信息,例如TokenURL、服務器返回信息都沒有截圖給出。

 

       以下內容你可能會感興趣:

OAuth簡介及sina微博開放平臺

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章