介绍
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("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 + " ");
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();