伙伴云客服论坛»论坛 S区 S软件开发 查看内容

0 评论

0 收藏

分享

Java Socket编程(三) 效劳器Sockets

文章来源:aspcn 作者:孙雯</p>
效劳器Sockets

            列表9.2是一个效劳器应用程序的一部分.

          列表9.2 一个简单的效劳器程序

          /**
          * 一个监听端口并提供HTML文档的程序.
          */
          class SimpleWebServer {
          public static void main(String args[])
          {
          ServerSocket serverSocket = null;
          Socket clientSocket = null;
          int connects = 0;
          try
          {
          {
          // 建立一个效劳器socket
          serverSocket = new ServerSocket(80, 5);
while (connects < 5)
{
// 等待连接
clientSocket = serverSocket.accept();
//效劳连接
ServiceClient(clientSocket);
connects++;
}
serverSocket.close();
}
catch (IOException ioe)
{
System.out.println("Error in SimpleWebServer: " + ioe);
}
}
public static void ServiceClient(Socket client)
throws IOException
{
DataInputStream inbound = null;
DataOutputStream outbound = null;
try
{
// 得到IO流
inbound = new DataInputStream( client.getInputStream());
outbound = new DataOutputStream( client.getOutputStream());
//格式化输出(回应头和很少的HTML文档)
StringBuffer buffer = PrepareOutput();
String inputLine;
while ((inputLine = inbound.readLine()) != null)
{
//假设到了HTTP恳求的尾部,就发送回应
if ( inputLine.equals("") )
{
outbound.writeBytes(buffer.toString());
break;
}
}
}
finally
{
// 肃清
System.out.println("Cleaning up connection: " + client);
tln("Cleaning up connection: " + client);
outbound.close();
inbound.close();
client.close();
client.close();
}
}
        效劳器并不是主动地建立连接.相反地,他们是被动地监听一个客户端的连接请示然后给他们效劳.效劳器是由类ServerSocket来建立的.下面的程序建立了一个效劳器端socket并把它绑定到80端口:

ServerSocket serverSocket = new ServerSocket(80, 5);

第一个参数是效劳器要监听的端口.第二个参数是可选的.API文档中说明了这是一个监听时间,但是在传统的socket程序中第二个参数是监听深度.一个效劳器可以同时接收多个连接恳求,但是每次只能处置一个.监听堆是一个无回答的连接恳求队列.上面的恳求建立一个连接来处置最后五个恳求.假设省略了后面的一个参数,则默认值是50.

ServerSocket serverSocket = new ServerSocket(80, 5);

一旦socket建立了并开端监听连接,进来的连接将会建立并放在监听堆.accetp()方法把在堆中的连接取出来.

Socket clientSocket = serverSocket.accept();

这个方法返回一个用来与来访者对话的客户端连接.效劳器自身不可能建立对话,相反地,效劳器socket会使用accept()方法来产生一个新的socket.效劳器socket照旧翻开并排列新的连接恳求.

与客户端socket一样,下面的一步建立输入和输出流:

DataInputStream inbound = new DataInputStream( clientSocket.getInputStream() ); DataOutputStream outbound = new DataOutputStream( clientSocket.getOutputStream() );

一般的I/O操作可以在新建的流中运用.在效劳器回应前它等待客户端发送一个空白的行.当会话完毕时,效劳器关闭流和客户端socket.假设在队列中没有请示将会呈现什么情况呢?那个方法将会等待一个的到来.这个行为叫阻塞.accept()方法将会阻塞效劳器线程直到一个呼叫到来.当5个连接处置完闭之后,效劳器退出.任何的在队列中的呼叫将会被取消.

所有的效劳器都要有以下的根本的步骤:

1.建立一个效劳器socket并开端监听.

2.使用accept()方法获得新的连接.

3.建立输入和输出流.

4.在已有的协议上产生会话.

5.关闭客户端流和socket.

6.回到第二步或者到第七步.

7.关闭效劳器socket.

回复

举报 使用道具

全部回复
暂无回帖,快来参与回复吧
本版积分规则 高级模式
B Color Image Link Quote Code Smilies

凉凉
注册会员
主题 23
回复 19
粉丝 0
|网站地图
快速回复 返回顶部 返回列表