URL类一般使用以下的构造方法建立一个URL对象:java
public URL(String spec) throws MalformedURLException
public URL(String protocol, String host,String file) throws MalformedURLException
URL对象调用
InputStream openStream()
方法能够返回一个输入流,该输入流指向URL对象所包含的资源。经过该输入流能够将服务器上的资源读入到客户端。编程
Internet上的主机有两种方式表示地址:服务器
www.sina.com.cn/202.108.37.40
。getByName(String s);
www.sina.com.cn/202.108.37.40
getLocalHost()
得到一个InetAddress对象,该对象含有本地机的域名和IP地址。IP地址标识Internet上的计算机,端口号标识正在计算机上运行的进程(程序)。端口号被规定为一个16位的0~65535之间的整数。
当两个程序须要通讯时,它们能够经过使用Socket类创建套接字对象并链接在一块儿(端口号与IP地址的组合得出一个网络套接字)。网络
客户端的程序使用Socket类创建负责链接到服务器的套接字对象。
创建链接到服务器的套接字对象:多线程
try{ Socket mysocket=new Socket(“http://192.168.0.78”,1880); } catch(IOException e) {}
与mysocket相关的方法socket
getInputStream()
得到一个输入流getOutputStream()
得到一个输出流getInputStream()
获得的输入流接到另外一个DataInputStream数据流上getOutputStream()
获得的输出流接到另外一个DataOutputStream数据流上服务器必须创建一个ServerSocket对象,该对象经过将客户端的套接字对象和服务器端的一个套接字对象链接起来,从而达到链接的目的。
创建ServerSocket对象:分布式
try22{ ServerSocket serverForClient =new ServerSocket(2010); } catch(IOException e){}
使用方法accept()将客户的套接字和服务器端的套接字链接起来,代码以下所示:学习
try{ Socket sc= serverForClient .accept(); } catch(IOException e){}
所谓“接收”客户的套接字链接就是accept()
方法会返回一个和客户端Socket对象相链接的Socket对象。url
客户端的套接字得到的输入\输出流和服务器端的套接字得到的输出\输入流互相链接.
.net
为了防止堵塞线程,服务器端收到一个客户的套接字后,就应该启动一个专门为该客户服务的线程。
在Example13_4中,客户使用Socket类不带参数的构造方法Socket()
建立一个套接字对象,该对象需调用
public void connect(SocketAddress endpoint) throws IOException
请求和参数SocketAddress指定地址的套接字创建链接。
为了使用connect方法,可使用SocketAddress的子类InetSocketAddress建立一个对象,
InetSocketAddress的构造方法是:InetSocketAddress(InetAddress addr, int port)
基于UDP的通讯和基于TCP的通讯不一样,基于UDP的信息传递更快,但不提供可靠性保证。
基于UDP通讯的基本模式是:
DatagramPacket(byte data[],int length,InetAddtress address,int port)
DatagramPack(byte data[],int offset,int length,InetAddtress address,int port)
DatagramSocket mail_out=new DatagramSocket();
mail_out.send(data_pack);
DatagramSocket(int port)
建立一个对象,其中的参数必须和待接收的数据包的端口号相同。DatagramSocket mail_in=new DatagramSocket(5666);
receive(DatagramPacket pack)
接受数据包。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
。
广播数据报涉及到地址和端口。
广播数据报是一种较新的技术,要广播或接收广播的主机都必须加入到同一个D类地址。
Java远程调用,RMI(Remote Method Invocation)是一种分布式技术,使用RMI可让一个虚拟机(JVM)上的应用程序请求调用位于网络上另外一处的JVM上的对象方法。习惯上称发出调用请求的虚拟机(JVM)为(本地)客户机,称接受并执行请求的虚拟机(JVM)为(远程)服务器。
java.rmi
包中Remote的子接口,即扩展Remote
接口。Remote
接口,RMI使用Remote
接口来标识远程对象,可是Remote中没有方法,所以建立远程对象的类须要实现Remote接口的一个子接口。rmiregistry
: 执行rimregistry
命令rebind(String name, Remote obj)
绑定一个远程对象到rmiregistry所管理的注册表中,该方法的name参数是URL格式,obj参数是远程对象,未来客户端的代理会经过name 找到远程对象obj。