13章 java网络编程
1.URL类是java.net包中的一个重要的类,使用URL创建对象的应用程序称为客户端程序。一个URL对象封装着一个具体资源的引用,表明客户要访问这个URL中的资源,客户运用URL对象可以获取URL中的资源,一个URL对象通常包含最基本三个信息:协议,地址和资源。协议闭必须是URL所在的java虚拟机支持的协议,比如常用的Http,Ftp,File。地址必须是连接有效的ip地址或地域名,资源可以是主机上任意一个文件。
URL类通常使用如下构造方法构造一个URL对象:
public URL (String spec) throws MalformedURLException
另一种构造方法public URL(String protocol,String host ,String file)throws MalformedURLException.该方法使用的协议,地址,资源分别由参数protocol , host 和file指定。
读取URL中的资源
URL对象调用InputStream openStream()方法可以返回一个输入流,该输入流指向URL对象所包含的资源通过该输入流可以将服务器上的资源读入客户端。
地址表示方式
域名 例如 www.tsinghua.edu.cn。
ip 地址 例如 202.108.35.210
获取地址
可以用InetAddress类的静态方法getByName(String s)将一个域名或ip地址传递给该方法的参数s,获取一个InetAddress对象,含有主机地址的域名和ip地址。
获取本地机的地址
使用InetAddress类的静态的方法getLocalHost()获取一个InetAddress对象,含有本地机器域名和ip地址
2.套接字
两个程序需要通信时,可以通过Socket类建立套接对象并连接在一起
客户端套接字
客户端程序使用Socket类建立负责连接到服务器的套接字对象。
Socker构造方法是Socket(String host,int port),参数host是服务器的ip地址,port是一个服务器端口。建立套接字可能发生IOException异常。
try {
Socket clientSocket =new Socket ("http://192.168.0.78",2010);
}
catch(IOException e){}
clientSocket 使用方法getOutputStream获得一个输出流。
ServerSocket对象与服务器客户端套接字
ServerSocket 的构造方法是SeverSocket(int port),port是一个端口。port必须和客户端呼叫的端口号相同。建立ServerSocket可能发生IOException异常。
当服务器的ServerSocket对象serverForClient建立后,可以使用方法accept(将客户端)的套接字和服务端的套接字连接起来
try{
Socket sc = serverForClient.accept()
;}
catch(IOException e){}
建立连接后服务端和客户端的套接对象可以调用getInetAddress()方法获取一个InetAddress对象,含有客户端的ip地址和域名,客户端套接字 的 则含服务器的IP地址和域名
使用多线程技术
可以用Socket类的不带参数的构造方法Socket()创造一个套接字对象,该套接字再调用public void connect(SocketAddress endpoint)throws IOException请求和参数SocketAddress指向指定地址的服务端的套接字建立连接,为了使用connect方法,可以使用SocketAddress 的子类InetSocketAddress创建一个对象,InetSocketAddress的构造方法是public InetSocketAddress(InetAddress addr,int port)
套接字通信中,有两个基本原则
(1)服务器应当启动一个专门的线程,在该线程中和客户端的套接字进行连接。
(2)由于套接字的输入流在读取信息时可能发生阻塞,客户端和服务端都需要在一个单独的线程中读取信息。
3.UDP数据报
发送数据包
用DatagramPacket类创建一个对象,称为数据包。
DatagramPacket(byte data[ ],int length,InetAddress address,int port)
有两个性质
1含有Data数组指定的数据
2该数据包发送地址为address 端口号是port的主机上。
DatagramPacket(byte data[ ],int length,int offset,InetAddress address,int port)
构造负责发送数据包的方法 例如
DatagramSocket mail_out=new DatagramSocket();
mail_out.send(data_pack);
接收数据包
1)首先用DatagramSocket的另一个构造方法DatagramSocket(int port) 创建一个对象,其中的参数必须和待接收的数据包的端口号相同。例如,如果发送方发送的数据包的端口是5666,那么如下创建DatagramSocket对象:
–DatagramSocket mail_in=new DatagramSocket(5666);
2)然后对象mail_in使用方法receive(DatagramPacket pack)接受数据包。
3)用 DatagramPack类的另外一个构造方法: DatagramPack(byte data[],int length)创建一个数据包,用于接收数据包,例如:
byte data[]=new byte[100];
int length=90;
DatagramPacket pack=new DatagramPacket(data,length);
mail_in.receive(pack);
–该数据包pack将接收长度是length字节的数据放入data。
4.广播数据报
广播数据报涉及到地址和端口。
广播数据报是一种较新的技术,要广播或接收广播的主机都必须加入到同一个D类地址
5.Java远程调用(RMI)
Java远程调用,RMI(Remote Method Invocation)是一种分布式技术,使用RMI可以让一个虚拟机(JVM)上的应用程序请求调用位于网络上另一处的JVM上的对象方法。习惯上称发出调用请求的虚拟机(JVM)为(本地)客户机,称接受并执行请求的虚拟机(JVM)为(远程)服务器。
(1)远程对象:
驻留在(远程)服务器上的对象是客户要请求的对象,称作远程对象。
(2)代理与存根(Stub):
代理的特点是它与远程对象实现了相同的接口。
存根(Stub):一种特殊的字节码,并让这个存根产生的对象为作为远程对象的代理。
(3)Remote接口
RMI为了标识一个对象是远程对象,即可以被客户请求的对象,要求远程对象必须实现java.rmi包中的Remote接口,也就是说只有实现该接口的类的实例才被RMI认为是一个远程对象。