|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
重复和并发服务器 所有的这些调用都可以掷出一个UnknownHostException违例.假如一台计算机没有连接上DNS服务器,或者主机的确没有找到,这个违例就会被掷出.假如一台计算机没有一个激活的TCP/IP配置,getLocalHost()也为失败并掷出一个违例. 一旦一个地址被确定了,数据报就可以被送出了.下面的程序传输了一个字符串给目的socket: String toSend = "This is the data to send!"); byte[] sendbuf = new byte[ toSend.length() ]; toSend.getBytes( 0, toSend.length(), sendbuf, 0 ); DatagramPacket sendPacket = new DatagramPacket( sendbuf, sendbuf.length, addr, port); clientSocket.send( sendPacket ); 首先,字符串必须被转变成一个字节数组.然后,一个新的DatagramPacket实例必须被建立.注重构建器的最后两个参数.因为要发送一个包,所以地址和端口必须被给定.一个applet可能可以知道它的服务器的地址,但是服务器如何知道它的客户机的地址呢.当任何一个包被收到后,返回的地址和端口会被解压出来,并通过getAddress()和getPort()方式得到.这就是一个服务器如何回应一个客户端的包: DatagramPacket sendPacket = new DatagramPacket( sendbuf, sendbuf.length, recvPacket.getAddress(), recvPacket.getPort() ); serverSocket.send( sendPacket ); 不像面向连接的操作,数据报服务器服务器其实比数据报客户端更简朴: 数据报服务器 一个数据报服务器的基本步骤: 1.在一个指定的端口上建立一个数据报socket. 2.用receive方式等待进来的包. 3.用特定的协议往返应收到的包. 4.回到第二步或继承第二步. 5.关闭数据报socket. 列表9.3演示了一人简朴的数据报回应服务器.它将回应它收到的包. 列表9.3.一个简朴的数据报回应服务器 import java.io.*; import java.net.*; public class SimpleDatagramServer { public static void main(String[] args) { DatagramSocket socket = null; DatagramPacket recvPacket, sendPacket; try { socket = new DatagramSocket(4545); while (socket != null) { recvPacket= new DatagramPacket(new byte[512], 512); socket.receive(recvPacket); sendPacket = new DatagramPacket( recvPacket.getData(), recvPacket.getLength(), recvPacket.getAddress(), recvPacket.getPort() ); socket.send( sendPacket ); } } catch (SocketException se) { System.out.println("Error in SimpleDatagramServer: " + se); } catch (IOException ioe) { System.out.println("Error in SimpleDatagramServer: " + ioe); 这个应用程序被当作一个重复的服务器.因为它只有在处理完一个进程以后才会接受另一个连接.更多的复杂服务器是并发的.它为每一个哀求分配一个线程,而不是来一个处理一个.所以看起来它在同时处理多人哀求.所有的商业的服务器都是并发的服务器. 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()方式在数据可用之前将会阻塞. 发送数据报 发送数据报是异常地简朴地,所有需要的只是一个地址.地址是由InetAddress类来建立的.这个类没有公共的构建器,但是它有几个static的方式,可以用来建立这个类的实例.下面的列表列出了建立InetAddress类的实例的方式: Public InetAddress Creation Methods InetAddress getByName(String host); InetAddress[] getAllByName(String host); InetAddress getLocalHost(); 得到本地主机的地址是异常地有用的,只有前面两个方式是用来发送数据包的.getByName()和getAllByName()需要目的主机的地址.第一个方式仅仅只是返回第一个符合条件的东西.第二个方式是必须的,因为一台计算机可能有多个地址.在这种情况下,这台计算机被称为multi-homed. 所有的建立的方式都被标记为static.它们必须像下面这样得到调用: InetAddress addr1 = InetAddress.getByName("merlin"); InetAddress addr2[] = InetAddress.getAllByName("merlin"); InetAddress addr3 = InetAddress.getLocalHost(); 返回类别: 教程 上一教程: Java连接SQL Server 2000 下一教程: 往JRE里增加字体 您可以阅读与"Java Socket编程(四)"相关的教程: · Java Socket编程(三) · Java Socket编程(五) · Java socket编程入门 · Java Socket编程中的一个秘密类 · Java Socket编程(三)-1 |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |