如何使用Java.net包中的下面三個類

本篇文章為大家展示了如何使用Java.net包中的下面三個類,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:國際域名空間、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、新區(qū)網(wǎng)站維護、網(wǎng)站推廣。

介紹

Java平臺在java.net包里來實現(xiàn)Java Socket。我們將使用Java.net包中的下面三個類來工作:

·URLConnection

·Socket

·ServerSocket

在java.net包里包含有更多的類,但是這些是你最經(jīng)常遇見的,讓我們從URLConnection開始,這個類提供了在你的java代碼里使用Socket的方法而無需了解Socket的底層機制。

甚至不用嘗試就可以使用sockets

連接到一個URL包括以下幾個步驟:

·創(chuàng)建一個URLConnection

·用不同的setter方法配置它

·連接到URLConnection

·與不同的getter方法進行交互

下面,我們來用一些例子示范怎樣使用URLConnection從一臺服務(wù)器上請求一份文檔。

URLClient類

我們將從URLClient類的結(jié)構(gòu)開始講起。

import java.io.*;
import java.net.*;
public class URLClient {
 protected URLConnection connection;
 public static void main(String[] args) {}
 public String getDocumentAt(String urlString) {}
}

注意:必須要先導(dǎo)入java.net和java.io包才行

我們給我們的類一個實例變量用于保存一個URLConnection

我們的類包含一個main()方法用于處理瀏覽一個文檔的邏輯流(logic flow),我們的類還包含了getDocumentAt()方法用于連接服務(wù)器以及請求文檔,下面我們將探究這些方法的細節(jié)。

瀏覽文檔

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()方法僅僅創(chuàng)建了一個新的URLClient類的實例并使用一個有效的URL String來調(diào)用getDocumentAt()方法。當(dāng)調(diào)用返回文檔,我們把它儲存在一個String里并把這個String輸出到控制臺上。然而,實際的工作是getDocumentAt()方法當(dāng)中完成的。

從服務(wù)器上請求一份文檔

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類型的參數(shù)包含我們想得到的那份文檔的URL。我們先創(chuàng)建一個StringBuffer用于保存文檔的行。接著,我們用傳進去的參數(shù)urlString來創(chuàng)建一個新的URL。然后,我們創(chuàng)建一個URLConnection并打開它:

URLConnection conn = url.openConnection();

一旦有了一個URLConnection,我們就獲得它的InputStream并包裝成InputStreamReader,然后我們又把它進而包裝成BufferedReader以至于我們能夠讀取從服務(wù)器獲得的文檔的行,我們在java代碼中處理socket的時候會經(jīng)常使用這種包裝技術(shù)。在我們繼續(xù)學(xué)習(xí)之前你必須熟悉它:

BufferedReader reader =new BufferedReader(new InputStreamReader(conn.getInputStream()));

有了BufferedReader,我們能夠容易的讀取文檔的內(nèi)容。我們在一個while...loop循環(huán)里調(diào)用reader上的readline()方法:

String line = null;

while ((line = reader.readLine()) != null)

document.append(line + "\n");

調(diào)用readLine()方法后從InputStream傳入行終止符(例如換行符)時才產(chǎn)生阻塞。如果沒有得到,它將繼續(xù)等待,當(dāng)連接關(guān)閉時它才會返回null,既然這樣,一旦我們獲得一個行,我們連同一個換行符把它追加到一個調(diào)用的文檔的StringBuffer上。這樣就保留了從服務(wù)器上原文檔的格式。

當(dāng)我們讀取所有行以后,我們應(yīng)該關(guān)閉BufferedReader:

reader.close();

如果提供給urlString的URL構(gòu)造器無效,則將會拋出一個MalformedUR特拉LException異常。同樣如果產(chǎn)生了其他的錯誤,例如從連接獲取InputStream時,將會拋出IOException。

總結(jié)

1.用一個你想連接的資源的有效的url String來實例化URL

2.連接到指定URL

3.包裝InputStream為連接在BufferedReader以至于你可以讀取行

4.用你的BufferedReader讀取文檔內(nèi)容

5.關(guān)閉BufferedReader

上述內(nèi)容就是如何使用Java.net包中的下面三個類,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前標題:如何使用Java.net包中的下面三個類
分享鏈接:http://muchs.cn/article26/jpgijg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、手機網(wǎng)站建設(shè)商城網(wǎng)站、定制開發(fā)、Google、網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)