java socket常用類之——URLConnection

來源:互聯網
上載者:User
 Java平台在java.net包裡來實現Socket。.net包中主要由下面三個類來工作:

  ·URLConnection  ·Socket  ·ServerSocket  在java.net包裡包含有更多的類,但是這些是你最經常遇見的,讓我們從URLConnection開始,這個類提供了在你的java代碼裡使用Socket的方法而無需瞭解Socket的底層機制。  甚至不用嘗試就可以使用sockets  串連到一個URL包括以下幾個步驟:  ·建立一個URLConnection  ·用不同的setter方法配置它  ·串連到URLConnection  ·與不同的getter方法進行互動  下面,我們來用一些例子示範怎樣使用URLConnection從一台伺服器上請求一份文檔。  URLClient類  我們將從URLClient類的結構開始講起。import java.io.*;
import java.net.*;
public class URLClient {
 protected URLConnection connection;
 public static void main(String[] args) {}
 public String getDocumentAt(String urlString) {}
}   注意:必須要先匯入java.net和java.io包才行  我們給我們的類一個執行個體變數用於儲存一個URLConnection  我們的類包含一個main()方法用於處理瀏覽一個文檔的邏輯流(logic flow),我們的類還包含了getDocumentAt()方法用於串連伺服器以及請求文檔,下面我們將探究這些方法的細節。  瀏覽文檔  main()方法用於處理瀏覽一個文檔的邏輯流(logic flow):public static void main(String[] args) {
 URLClient client = new URLClient();
 String yahoo = client.getDocumentAt("http://www.yahoo.com");
 System.out.println(yahoo);
}   我們的main()方法僅僅建立了一個新的URLClient類的執行個體並使用一個有效URL String來調用getDocumentAt()方法。當調用返迴文檔,我們把它儲存在一個String裡並把這個String輸出到控制台上。然而,實際的工作是getDocumentAt()方法當中完成的。  從伺服器上請求一份文檔  getDocumentAt()方法處理在實際工作中如何從web上得到一份文檔:public String getDocumentAt(String urlString) {
 StringBuffer document = new StringBuffer();
 try {
  URL url = new URL(urlString);
  URLConnection conn = url.openConnection();
  BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));
  String line = null;
  while ((line = reader.readLine()) != null)
   document.append(line + "/n");
   reader.close();
 } catch (MalformedURLException e) {
  System.out.println("Unable to connect to URL: " + urlString);
 } catch (IOException e) {
  System.out.println("IOException when connecting to URL: " + urlString);
 }
 return document.toString();
}   getDocumentAt()方法有一個String類型的參數包含我們想得到的那份文檔的URL。我們先建立一個StringBuffer用於儲存文檔的行。接著,我們用傳進去的參數urlString來建立一個新的URL。然後,我們建立一個URLConnection並開啟它:URLConnection conn = url.openConnection();  一旦有了一個URLConnection,我們就獲得它的InputStream並封裝成InputStreamReader,然後我們又把它進而封裝成BufferedReader以至於我們能夠讀取從伺服器獲得的文檔的行,我們在java代碼中處理socket的時候會經常使用這種封裝技術。在我們繼續學習之前你必須熟悉它:BufferedReader reader =new BufferedReader(new InputStreamReader(conn.getInputStream()));   有了BufferedReader,我們能夠容易的讀取文檔的內容。我們在一個while...loop迴圈裡調用reader上的readline()方法:String line = null;
while ((line = reader.readLine()) != null)
document.append(line + "/n");   調用readLine()方法後從InputStream傳入行終止符(例如分行符號)時才產生阻塞。如果沒有得到,它將繼續等待,當串連關閉時它才會返回null,既然這樣,一旦我們獲得一個行,我們連同一個分行符號把它追加到一個調用的文檔的StringBuffer上。這樣就保留了從伺服器上原文檔的格式。  當我們讀取所有行以後,我們應該關閉BufferedReader:reader.close();   如果提供給urlString的URL構造器無效,則將會拋出一個MalformedUR特拉LException異常。同樣如果產生了其他的錯誤,例如從串連擷取InputStream時,將會拋出IOException。  總結  1.用一個你想串連的資源的有效url String來執行個體化URL  2.串連到指定URL  3.封裝InputStream為串連在BufferedReader以至於你可以讀取行  4.用你的BufferedReader讀取文檔內容  5.關閉BufferedReader
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.