看來微博在中國又有一次不可忽略的發展了,由於昨天有這麼一個新聞「中國首屆微博開發者大會」,官網以下圖:html
要使用sina微博開放平臺的API,應先獲取sina分配的App key 和App Secret,下面是我建立應用以後sina分配的App key 和App Secret(這個但是要保密的哦)。java
修改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()。服務器
- 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();
- }
- }
- }
request.jsp,用於提供 callback_url(這裏咱們自定義爲下文中的callback.jsp),當獲取獲得RequestToken以後,保存該RequestToken到Session中,並將頁面重定向到callback.jsp進行驗證、受權。session
- <%@ page contentType="text/html;charset=utf-8" %>
- <%@ page language="java" import="weibo4j.*" %>
- <%@ page language="java" import="weibo4j.http.*" %>
- <%@ page language="java" import="weibo4j.util.*" %>
- <jsp:useBean id="weboauth" scope="session" class="weibo4j.examples.WebOAuth" />
- <%
- if("1".equals(request.getParameter("opt")))
- {
- // 傳入callback_url
- String callback_url = "http://localhost:8080/sinaweibo/callback.jsp";
- RequestToken requestToken = weboauth.getRequestToken(callback_url);
- if(requestToken != null){
- out.println(requestToken.getToken());
- out.println(requestToken.getTokenSecret());
- session.setAttribute("requestToken",requestToken);
- String url = requestToken.getAuthorizationURL()+"&oauth_callback="+callback_url;
- System.out.println("AuthorizationURL:" + url);
- //BareBonesBrowserLaunch.openURL(callback_url);
- //response.sendRedirect(requestToken.getAuthorizationURL());
- // 重定向到附加了callback_url回調地址的sina微博認證頁面
- response.sendRedirect(url);
- }else{
- out.println("request error");
- }
- }else{
- %>
- <a href="request.jsp?opt=1">請點擊進行Web方式的OAuth認證!</a>
- <% } %>
callback.jsp,在上一步中重定向以後,callback_url 後面會被附加了oauth_verifier參數,此時咱們根據保存在 Session中的RequestToken和獲取到的oauth_verifier參數申請得到AccessToken。一旦得到AccessToken,咱們再把頁面重定向到編寫微博的頁面writeWeibo.html。app
- <%@ page contentType="text/html;charset=utf-8" %>
- <%@ page language="java" import="weibo4j.http.*" %>
- <%@ page language="java" import="weibo4j.*" %>
- <jsp:useBean id="weboauth" scope="session" class="weibo4j.examples.WebOAuth" />
- <%
- // 得到HTTP請求中的 oauth_verifier 參數
- String verifier=request.getParameter("oauth_verifier");
- out.println("oauth_verifier:"+verifier);
- System.out.println("oauth_verifier:"+verifier);
- if(verifier != null){
- RequestToken requestToken = (RequestToken)session.getAttribute("requestToken");
- if(requestToken != null){
- AccessToken accessToken = weboauth.gettAccessToken(requestToken,verifier);
- if(accessToken != null){
- try{
- session.setAttribute("accessToken",accessToken);
- out.println("5 秒後轉到 writeWeibo.html");
- Thread.sleep(5000);
- response.sendRedirect("http://localhost:8080/sinaweibo/writeWeibo.html");
- }catch(Exception e){
- e.printStackTrace();
- }
- }else{
- out.println("access token request error");
- }
- }else{
- out.println("request token session error");
- }
- }else{
- out.println("verifier String error");
- }
- %>
writeWeibo.html,很簡單的HTML文件。jsp
- <html>
- <head><title>發佈sina微博</title></head>
- <body bgcolor="#d0d0d0" >
- <form action="updateWeibo.jsp" method="post">
- 請在這裏寫上140字符之內的文本:</br>
- <textarea name="weiboText" rows="3" cols="30">測試新浪微博!</textarea></br>
- <input type="submit" value="發佈">
- <input type="reset" value="清除"></br>
- </form>
- </body>
- </html>
updateWeibo.jsp,用於發表文本微博,即調用WebOAuth.java 中的update方法。ide
- <%@ page contentType="text/html;charset=utf-8" %>
- <%@ page language="java" import="weibo4j.http.*" %>
- <%@ page language="java" import="weibo4j.*" %>
- <jsp:useBean id="weboauth" scope="session" class="weibo4j.examples.WebOAuth" />
- <%
- AccessToken accessToken = (AccessToken)session.getAttribute("accessToken");
- String weiboText = (String)request.getParameter("weiboText");
- // 連續發表一樣的微博內容會返回400錯誤
- weboauth.update(accessToken, weiboText);
- out.println("微博發表成功!");
- %>
運行以前咱們要準備好 Tomcat ,並將上面的源文件放到正確的目錄中。此外,還應該在\WEB-INF\lib目錄下添加SDK包中帶有的commons-httpclient-3.1.jar 包,以及我本身編譯、打包後的weibo4j.jar(裏面是sina微博開放平臺中的具體Java實現)。
運行Tomcat,在瀏覽器中訪問request.jsp 頁面,以下圖:
點擊其中的連接,以下圖(注意地址欄的變化):
其中地址欄的URL以下:
填上具體有效的sina微博帳號、密碼並受權。如下是填上了我測試用的微博帳號並受權的結果:
其中地址欄的URL以下:
http://localhost:8080/sinaweibo/writeWeibo.html
點擊「發佈」,以下圖:
登陸微博查看一下,以下圖:
查看一下該帳號所受權的應用列表:
至此,關於OAuth方式使用sina微博開放平臺來發布微博就大概是這個過程。
小結:
1、其實還有好多細節沒能講到,我也是嘗試了好屢次才一點點發現問題、理解問題、再到解決問題;
2、若是瀏覽器中已經保存了咱們登陸sina微博的帳號信息的Cookie,那麼在受權時不用輸入帳號信息,固然也能夠修改不用當前帳號進行受權;
3、還有控制檯輸入的一些信息,例如Token、URL、服務器返回信息都沒有截圖給出。
如下內容你可能會感興趣: