程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> 關於JAVA >> 應用Java經由過程OAuth協定驗證發送微博的教程

應用Java經由過程OAuth協定驗證發送微博的教程

編輯:關於JAVA

應用Java經由過程OAuth協定驗證發送微博的教程。本站提示廣大學習愛好者:(應用Java經由過程OAuth協定驗證發送微博的教程)文章只能為提供參考,不一定能成為您想要的結果。以下是應用Java經由過程OAuth協定驗證發送微博的教程正文


固然新浪微博開放平台中供給各類說話版本的開辟 SDK 下載,也各自附有一些根本接口挪用的 Demo 和接口解釋文檔。然則這幾天的耐煩測驗考試以後,感到新浪微博開放平台上的入門指點和下載到的 Java 開辟包 weibo4j 包外面的 Demo 應用正文有些紛歧致。再加上本身融會才能無限,招致碰到好些摸不著腦筋的困難。不外幸虧沒有廢棄去測驗考試弄懂它。空話少說,上面是我進修的進程。
 
想要經由過程挪用新浪微博開放平台 API 開辟本身的微博運用,第一步是具有sina 微博賬號和CSDN 賬號,由於我們要同時用這兩個賬號創立微博運用,以此取得 App key 和 Secret key 。那 App key 和 Secret key 有甚麼用?
 
其實我單單看了sina 微博開放平台的一系列解釋都不怎樣懂得App key 和 Secret key 有啥用。由於加倍重點是必需懂得 OAuth 認證、受權的全部流程,和在全部OAuth 認證、受權流程中好幾個 Token 、4個 URL的感化。
 
剛開端碰到完整沒個概念的 OAuth 時,認為就沒戲進修不下去了。好在搜到上面這些文章,關於懂得 OAuth 異常有贊助,鏈接以下:

  • OAUTH協定簡介
  • 基於 OAuth 平安協定的 Java 運用編程
  • 在Twitter運用中應用OAuth

在 OAuth 中有3個介入者,分離是 User 、Service Provider 、Consumer 。假定我要開辟一個基於 sina 微博開放平台的運用(App),供其他 sina 微博用戶應用。它們的對應關系以下:

  • User  =>  想要應用此App的sina微博用戶
  • Provider  =>  sina微博開放平台
  • Consumer  =>  App

其實我們這個 App 關於 User 和 Provider(sina微博平台)來講,相當於一個第三方運用。作為第三方的 App 想要拜訪 User保留於 sina微博平台中的資本,確定必需經由一系列認證和受權以後能力夠行得通。

 
上面是基於我對全部 OAuth 認證、受權流程的懂得畫成的圖(可以看一下跳過,當對前面的一些概念有必定懂得以後再回頭看看這流程圖):

聯合下面的流程圖,上面是我對這些術語的懂得和各個流程的描寫:
Consumer key 、Consumer Secret :在sina 微博開放平台分離稱為 App key、Secret key。Consumer向 Provider 請求願望可以或許挪用其開放 API,請求經由過程後由 Provider 分派給相符其請求的 Consumer ,用於獨一標識該 Consumer 相符 Provider 的請求。
對應於上圖的流程 1 和 2。
 
Request Token 、Request Secret :當 User 拜訪 Consumer 並願望可以或許取得其特別辦事,該辦事由 Consumer 對 User 本身寄存在 Provider 中的資本停止整合操作以後前往。此時 Consumer 向 Provider 要求取得 Requst Token,用於獨一標識該 Consumer 與該 User 的特定聯系關系。
對應於上圖的流程 3 、4 、5。
 
至流程 6 ,Consumer 必需把 User 引誘到Provider所供給的 OAuth 認證、受權頁面,其實就是閱讀重視定向到附加有 Request Token 和 Request Secret 參數的 authenticationURL。該 URL 由 Provider 供給。
 
接上去流程 7 和 8 中 User 受權該 Consumer(普通是經由過程輸出賬號、暗碼登錄罷了),則 Provider 將重定向到流程 1 中 Consumer 供給的 Callback_URL ,而且在該 URL 參數中附加了 OAuth Token 和OAuth Verifier 。
 
流程 9 是 Consumer 經由過程之前已從 Provider 那邊獲得來的 Request Token 再次要求 Provider 以獲得 Access Token 。
 
Access Token 、 Access Secret :若流程 10 中 Provider 前往一個未經 User 受權的 Access Token ,它用於獨一標識特定 Consumer 可以拜訪某 User 寄存在 Provider 中的資本、信息。那末 Consumer 便可以開端應用獲得到的 Access Token 和 Access Secret 拜訪對應 User 寄存在 Provider 中的資本。
經由流程 11 中對 User 信息的整合、操作以後,便可以將特定的辦事成果前往給 User 了。
 
經由過程下面關於 OAuth 流程的懂得,我們曉得其實 User 完整未將本身登錄 Provider 所需的賬號、暗碼等洩漏給第三方的 Consumer 。同時 User 又能應用到 Consumer 的特別辦事。真是很奇妙的而又平安的操作流程啊!     
       另外,上圖中 Consumer 有 3 次與 Provider 收回分歧的要求,其實就是由 Provider 供給 3 個分歧感化的 URL 給 Consumer 拜訪。在 sina 微博開放平台中這 3 個 URL 的截圖以下:

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()。

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停止驗證、受權。
<%@ 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。

<%@ 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文件。
<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辦法。
<%@ 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以下:
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、還有掌握台輸出的一些信息,例如Token、URL、辦事器前往信息都沒有截圖給出。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved