温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何使用Java.net包中的下面三个类

发布时间:2021-11-20 16:59:07 来源:亿速云 阅读:126 作者:柒染 栏目:编程语言

本篇文章为大家展示了如何使用Java.net包中的下面三个类,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

介绍

Java平台在java.net包里来实现Java 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 + "\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类型的参数包含我们想得到的那份文档的URL。我们先创建一个StringBuffer用于保存文档的行。接着,我们用传进去的参数urlString来创建一个新的URL。然后,我们创建一个URLConnection并打开它:

URLConnection conn = url.openConnection();

一旦有了一个URLConnection,我们就获得它的InputStream并包装成InputStreamReader,然后我们又把它进而包装成BufferedReader以至于我们能够读取从服务器获得的文档的行,我们在java代码中处理socket的时候会经常使用这种包装技术。在我们继续学习之前你必须熟悉它:

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

有了BufferedReader,我们能够容易的读取文档的内容。我们在一个while...loop循环里调用reader上的readline()方法:

String line = null;

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

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

调用readLine()方法后从InputStream传入行终止符(例如换行符)时才产生阻塞。如果没有得到,它将继续等待,当连接关闭时它才会返回null,既然这样,一旦我们获得一个行,我们连同一个换行符把它追加到一个调用的文档的StringBuffer上。这样就保留了从服务器上原文档的格式。

当我们读取所有行以后,我们应该关闭BufferedReader:

reader.close();

如果提供给urlString的URL构造器无效,则将会抛出一个MalformedUR特拉LException异常。同样如果产生了其他的错误,例如从连接获取InputStream时,将会抛出IOException。

总结

1.用一个你想连接的资源的有效的url String来实例化URL

2.连接到指定URL

3.包装InputStream为连接在BufferedReader以至于你可以读取行

4.用你的BufferedReader读取文档内容

5.关闭BufferedReader

上述内容就是如何使用Java.net包中的下面三个类,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI