談笑有鴻儒,往來無白丁

          在恰當的時間、地點以恰當的方式表達給恰當的人...  閱讀的時候請注意分類,佛曰我日里面是談笑文章,其他是各個分類的文章,積極的熱情投入到寫博的隊伍中來,支持blogjava做大做強!向dudu站長致敬>> > 我的微博敬請收聽

          Java平臺在java.net包里來實現Socket。在這本文中,我們將使用Java.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(" 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

          主站蜘蛛池模板: 宝清县| 洮南市| 济宁市| 乐都县| 富源县| 资兴市| 三亚市| 葫芦岛市| 济源市| 大姚县| 蒙城县| 龙门县| 青海省| 西藏| 石景山区| 铜川市| 礼泉县| 南皮县| 萝北县| 将乐县| 扎鲁特旗| 台安县| 汝南县| 莒南县| 安吉县| 大同市| 富平县| 大埔县| 连城县| 平泉县| 渭南市| 孙吴县| 霍城县| 富民县| 普陀区| 双流县| 柞水县| 公主岭市| 普格县| 定边县| 秀山|