1.URL类
一个URL对象通常包含最基本的三部分信息:协议、地址和资源。
URL的构造方法:
(1)public URL(String spec) throws MalformedURLException
(2)public URL(String protocol, String host,String file) throws MalformedURLException 该构造方法使用的协议、地址和资源分别由参数protocol、host和file指定。
URL对象调用
InputStream openStream()方法 可以返回一个输入流,该输入流指向URL对象所包含的资源。通过该输入流可以将服务器上的资源读入到客户端。
2.InetAddress类
地址的表示
(1)域名 例如 www.tsinghua.edu.cn。
(2)IP地址 例如 202.108.35.210;
java.net包中的InetAddress类对象含有一个Internet主机地址的域名和IP地址,例如 www.sina.com.cn/202.108.37.40 。
(3)获取Internet上主机的地址
可以使用InetAddress类的静态方法getByName(String s);
获得一个InetAddress对象,该对象含有主机地址的域名和IP地址,该对象用如下格式表示它包含的信息:
www.sina.com.cn/202.108.37.40.
(4)获取本地机的地址
我们可以使用InetAddress类的静态方法getLocalHost()获得一个InetAddress对象,该对象含有本地机的域名和IP地址。
3.套接字
(1)网络通信使用 IP地址标识Internet上的计算机,端口号标识正在计算机上运行的进程(程序)。端口号被规定为一个16位的0~65535之间的整数。
(2)客户端程序使用Socket类建立负责链接到服务器的套接字对象。
(3)建立连接到服务器的套接字对象:
try{ Socket mysocket=new Socket(“http://192.168.0.78”,1880);
}
catch(IOException e)
{ }
(4)与mysocket相关的方法
getInputStream()获得一个输入流
getOutputStream()获得一个输出流
用getInputStream()得到的输入流接到另一个DataInputStream数据流上
用getOutputStream()得到的输出流接到另一个DataOutputStream数据流上
(5)服务器必须建立一个ServerSocket对象,该对象通过将客户端的套接字对象和服务器端的一个套接字对象连接起来,从而达到连接的目的。
(6)使用方法accept()将客户端的套接字和服务器端的套接字连接起来。
代码如下所示:
try{ Socket sc= serverForClient .accept();
}
catch(IOException e){}
(7)所谓“接收”客户的套接字连接就是accept()方法会返回一个和客户端Socket对象相连接的Socket对象。
(8)使用多线程技术:
套接字通信的两个基本原则:
服务器应当启动一个专门的线程,在该线程中和客户的套接字建立连接。
由于套接字的输入流在读取信息时可能发生阻塞,客户端和服务器端都需要在一个单独的线程中读取信息。
4.UDP数据报
(1)基于UDP的通信和基于TCP的通信不同,基于UDP的信息传递更快,但不提供可靠性保证。.
(2)基于UDP通信的基本模式是:
将数据打包,称为数据包(好比将信件装入信封一样),然后将数据包发往目的地。
接受别人发来的数据包(好比接收信封一样),然后查看数据包中的内容。
(3)用DatagramPacket类将数据打包,即用DatagramPacket类创建一个对象,称为数据包。用DatagramPacket的以下两个构造方法创建待发送的数据包:
DatagramPacket(byte data[],int length,InetAddtress address,int port)
DatagramPack(byte data[],int offset,int length,InetAddtress address,int port)
(4)用DatagramSocket类的不带参数的构造方法:DatagramSocket()创建一个对象,该对象负责发送数据包。例如:
DatagramSocket mail_out=new DatagramSocket();
mail_out.send(data_pack);
(5)接收数据包
首先用DatagramSocket的另一个构造方法DatagramSocket(int port) 创建一个对象,其中的参数必须和待接收的数据包的端口号相同。
然后对象mail_in使用方法receive(DatagramPacket pack)接受数据包。
用 DatagramPack类的另外一个构造方法: DatagramPack(byte data[],int length)创建一个数据包,用于接收数据包。
该数据包pack将接收长度是length字节的数据放入data。
5.Java远程调用(RMI)
Java远程调用,RMI(Remote Method Invocation)是一种分布式技术,使用RMI可以让一个虚拟机(JVM)上的应用程序请求调用位于网络上另一处的JVM上的对象方法。习惯上称发出调用请求的虚拟机(JVM)为(本地)客户机,称接受并执行请求的虚拟机(JVM)为(远程)服务器。
(1)远程对象及其代理
远程对象:
驻留在(远程)服务器上的对象是客户要请求的对象,称作远程对象。
代理与存根(Stub):
代理的特点是它与远程对象实现了相同的接口。
存根(Stub):一种特殊的字节码,并让这个存根产生的对象为作为远程对象的代理。
Remote接口
RMI为了标识一个对象是远程对象,即可以被客户请求的对象,要求远程对象必须实现java.rmi包中的Remote接口,也就是说只有实现该接口的类的实例才被RMI认为是一个远程对象