无论FTP客户程序,还是HTTP客户程序,或是其他基于特定应用层协议的客户程序,在与远程服务器通信时,都需要建立与远程服务器的连接,然后发送和接收与协议相符的数据。客户程序还需要对服务器发送的数据进行处理,有时要把他们转换为相应的Java对象。Java对客户程序的通信过程进行了抽象,提供了通用的协议处理框架。这个框架封装了Socket,主要包括以下几个类。
(1)URL类:同一资源定位符(Uniform Resource Locator),表示客户程序要访问的远程资源
(2) URLConnection类:表示客户程序与远程服务器的连接。客户程序可以从URLConnection类中获得数据输入流和输出流。
(3) URLStreamHandler类:协议处理器,主要负责创建与协议相关的URLConnection对象。
(4) ContentHandler类:内容处理器,负责解析服务器发送的数据,把它转化为相应的Java对象。
以上类都位于java.net包中,除了URL类为具体类以外,其余的3个类都是抽象类,对于一种具体的协议,需要创建相应的URLConnection、URLStreamHandler和ContentHandler具体子类。
import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStream; import java.net.URL; /** * @author 作者 E-mail: * @version 创建时间:2015-10-3 下午04:24:07 类说明 */ public class HttpClient1 { public static void main(String[] args) { try { URL url = new URL("http://www.baidu.com"); InputStream in = url.openStream(); ByteArrayOutputStream output = new ByteArrayOutputStream(); byte[] buffer = new byte[1024]; int len = -1; while ((len = in.read(buffer)) != -1) { output.write(buffer, 0, len); } System.err.println(new String(output.toByteArray())); } catch(IOException ex) { ex.printStackTrace(); } } }
public class ByteArrayOutputStream extends OutputStream
此类实现了一个输出流,其中的数据被写入一个 byte 数组。缓冲区会随着数据的不断写入而自动增长。可使用 toByteArray()
和 toString()
获取数据。
关闭 ByteArrayOutputStream 无效。此类中的方法在关闭此流后仍可被调用,而不会产生任何 IOException。