public String getDocumentAt(String urlString) {
StringBuffer document = new StringBuffer();
try {
URL url = new URL(urlString);
URLConnection conn = urlopenConnection();
BufferedReader reader = new BufferedReader(new InputStreamReader(conngetInputStream()));
String line = null;
while ((line = readerreadLine()) != null)
documentappend(line + \n);
readerclose();
} catch (MalformedURLException e) {
Systemoutprintln(Unable to connect to URL: + urlString);
} catch (IOException e) {
Systemoutprintln(IOException when connecting to URL: + urlString);
}
return documenttoString();
}
getDocumentAt()方法有一个String类型的参数包含我们想得到的那份文档的URL我们先创建一个StringBuffer用于保存文档的行接着我们用传进去的参数urlString来创建一个新的URL然后我们创建一个URLConnection并打开它
URLConnection conn = urlopenConnection();
一旦有了一个URLConnection我们就获得它的InputStream并包装成InputStreamReader然后我们又把它进而包装成BufferedReader以至于我们能够读取从服务器获得的文档的行我们在java代码中处理socket的时候会经常使用这种包装技术在我们继续学习之前你必须熟悉它
BufferedReader reader =new BufferedReader(new InputStreamReader(conngetInputStream()));
有了BufferedReader我们能够容易的读取文档的内容我们在一个whileloop循环里调用reader上的readline()方法
String line = null;
while ((line = readerreadLine()) != null)
documentappend(line + \n);
调用readLine()方法后从InputStream传入行终止符(例如换行符)时才产生阻塞如果没有得到它将继续等待当连接关闭时它才会返回null既然这样一旦我们获得一个行我们连同一个换行符把它追加到一个调用的文档的StringBuffer上这样就保留了从服务器上原文档的格式
当我们读取所有行以后我们应该关闭BufferedReader:
readerclose();
如果提供给urlString的URL构造器无效则将会抛出一个MalformedUR特拉LException异常同样如果产生了其他的错误例如从连接获取InputStream时将会抛出IOException
总结
.用一个你想连接的资源的有效的url String来实例化URL
.连接到指定URL
.包装InputStream为连接在BufferedReader以至于你可以读取行
.用你的BufferedReader读取文档内容
.关闭BufferedReader
[] []