国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

a Socket編程中的一個(gè)秘密類

2019-11-17 06:24:48
字體:
供稿:網(wǎng)友

  介紹

  java平臺(tái)在java.net包里來實(shí)現(xiàn)Socket。在這本文中,我們將使用Java.net包中的下面三個(gè)類來工作:

  ?URLConnection

  ?Socket

  ?ServerSocket

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

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

  連接到一個(gè)URL包括以下幾個(gè)步驟:

  ?創(chuàng)建一個(gè)URLConnection

  ?用不同的setter方法配置它

  ?連接到URLConnection

  ?與不同的getter方法進(jìn)行交互

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

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包才行

  我們給我們的類一個(gè)實(shí)例變量用于保存一個(gè)URLConnection

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

瀏覽文檔

  main()方法用于處理瀏覽一個(gè)文檔的邏輯流(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)建了一個(gè)新的URLClient類的實(shí)例并使用一個(gè)有效的URL String來調(diào)用getDocumentAt()方法。當(dāng)調(diào)用返回文檔,我們把它儲(chǔ)存在一個(gè)String里并把這個(gè)String輸出到控制臺(tái)上。然而,實(shí)際的工作是getDocumentAt()方法當(dāng)中完成的。

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

  getDocumentAt()方法處理在實(shí)際工作中如何從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 + " ");
   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()方法有一個(gè)String類型的參數(shù)包含我們想得到的那份文檔的URL。我們先創(chuàng)建一個(gè)StringBuffer用于保存文檔的行。接著,我們用傳進(jìn)去的參數(shù)urlString來創(chuàng)建一個(gè)新的URL。然后,我們創(chuàng)建一個(gè)URLConnection并打開它:

URLConnection conn = url.openConnection();

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

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

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

String line = null;
while ((line = reader.readLine()) != null)
document.append(line + " ");

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

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

reader.close();

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

  總結(jié)

  1.用一個(gè)你想連接的資源的有效的url String來實(shí)例化URL

  2.連接到指定URL

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

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

  5.關(guān)閉BufferedReader

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 石渠县| 美姑县| 永胜县| 建湖县| 江源县| 崇左市| 夏邑县| 西充县| 远安县| 栾城县| SHOW| 视频| 永寿县| 旬邑县| 东丰县| 太湖县| 砀山县| 肥乡县| 鄱阳县| 阿合奇县| 潜江市| 唐山市| 宁武县| 保亭| 健康| 台中市| 绥中县| 依安县| 阜阳市| 化隆| 丰台区| 五家渠市| 延安市| 卫辉市| 宁城县| 杭州市| 凤台县| 古蔺县| 祁连县| 噶尔县| 芜湖市|