重复和并发服务器
这个应用程序被当作一个重复的服务器.因为它只有在处理完一个进程以后才会接受另一个连接.更多的复杂服务器是并发的.它为每一个请求分配一个线程,而不是来一个处理一个.所以看起来它在同时处理多人请求.所有的商业的服务器都是并发的服务器.
java数据报类
不像面向连接的类,数据报的客户端和服务器端的类在表面上是一样的.下面的程序建立了一个客户和服务器商的数据报sockets:
datagramsocket serversocket = new datagramsocket( 4545 );
datagramsocket clientsocket = new datagramsocket();
服务器用参数4545来指定端口号,由于客户端将要呼叫服务器,客户端可以利用可利用的端口.如果省略第二个参数,程序会让操作系统分配一个可用的端口.客户端可以请求一个指定的端口,但是如果其它的应用程序已经绑定到这个端口之上,请求将会失败.如果你的意图不是作为一个服务器,最好不要指定端口.
由于流不能由交谈得到,那么我么如何与一个数据报socket进行对话.答案在于数据报类.
接收数据报
datagrampacket类是用来通过datagramsocket类接收和发送数据的类.packet类包括了连接信息和数据.就如前面所说的一样,数据报是自身独立的传输单元.datagrampacket类压缩了这些单元.下面的程序表示了用一个数据报socket来接收数据:
datagrampacket packet = new datagrampacket(new byte[512], 512); clientsocket.receive(packet);
clientsocket.receive(packet);
packet的构建器需要知道将得到的数据放在哪儿.一个512字节的缓存被建立并且作为构建器的第二个参数.每二个构建器参数是缓存的大小.就像serversocket类的accept()方法一样,receive()方法在数据可用之前将会阻塞.
发送数据报
发送数据报是非常地简单地,所有需要的只是一个地址.地址是由.netaddress类来建立的.这个类没有公共的构建器,但是它有几个static的方法,可以用来建立这个类的实例.下面的列表列出了建立.netaddress类的实例的方法:
public .netaddress creation methods
.netaddress getbyname(string host);
.netaddress[] getallbyname(string host);
.netaddress getlocalhost();
得到本地主机的地址是非常地有用的,只有前面两个方法是用来发送数据包的.getbyname()和getallbyname()需要目的主机的地址.第一个方法仅仅只是返回第一个符合条件的东西.第二个方法是必须的,因为一台计算机可能有多个地址.在这种情况下,这台计算机被称为multi-homed.
所有的建立的方法都被标记为static.它们必须像下面这样得到调用:
.netaddress addr1 = .netaddress.getbyname("merlin");
.netaddress addr2[] = .netaddress.getallbyname("merlin");
.netaddress addr3 = .netaddress.getlocalhost();
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器