服务器Sockets
列表是一个服务器应用程序的一部分
列表 一个简单的服务器程序
/**
* 一个监听端口并提供HTML文档的程序
*/
class SimpleWebServer
{
public static void main(String args[])
{
ServerSocket serverSocket = null;
Socket clientSocket = null;
int connects = ;
try
{
// 建立一个服务器socket
serverSocket = new ServerSocket( );
while (connects < )
{
// 等待连接
clientSocket = serverSocketaccept();
//服务连接
ServiceClient(clientSocket);
connects++;
}
serverSocketclose();
}
catch (IOException ioe)
{
Systemoutprintln(Error in SimpleWebServer: + ioe);
}
}
public static void ServiceClient(Socket client)
throws IOException
{
DataInputStream inbound = null;
DataOutputStream outbound = null;
try
{
// 得到IO流
inbound = new DataInputStream( clientgetInputStream());
outbound = new DataOutputStream( clientgetOutputStream());
//格式化输出(回应头和很少的HTML文档)
StringBuffer buffer = PrepareOutput();
String inputLine;
while ((inputLine = inboundreadLine()) != null)
{
//如果到了HTTP请求的尾部就发送回应
if ( inputLineequals() )
{
outboundwriteBytes(buffertoString());
break;
}
}
}
finally
{
// 清除
Systemoutprintln(Cleaning up connection: + client);
tln(Cleaning up connection: + client);
outboundclose();
inboundclose();
clientclose();
clientclose();
}
}
}
服务器Sockets
服务器并不是主动地建立连接相反地他们是被动地监听一个客户端的连接请示然后给他们服务服务器是由类ServerSocket来建立的下面的程序建立了一个服务器端socket并把它绑定到端口
ServerSocket serverSocket = new ServerSocket( );
第一个参数是服务器要监听的端口第二个参数是可选的API文档中说明了这是一个监听时间但是在传统的socket程序中第二个参数是监听深度一个服务器可以同时接收多个连接请求但是每次只能处理一个监听堆是一个无回答的连接请求队列上面的请求建立一个连接来处理最后五个请求如果省略了后面的一个参数则默认值是
ServerSocket serverSocket = new ServerSocket( );
一旦socket建立了并开始监听连接进来的连接将会建立并放在监听堆accetp()方法把在堆中的连接取出来
Socket clientSocket = serverSocketaccept();
这个方法返回一个用来与来访者对话的客户端连接服务器本身不可能建立对话相反地服务器socket会使用accept()方法来产生一个新的socket服务器socket依旧打开并排列新的连接请求
与客户端socket一样下面的一步建立输入和输出流
DataInputStream inbound = new DataInputStream( clientSocketgetInputStream());
DataOutputStream outbound = new DataOutputStream( clientSocketgetOutputStream() );
一般的I/O操作可以在新建的流中运用在服务器回应前它等待客户端发送一个空白的行当会话结束时服务器关闭流和客户端socket如果在队列中没有请示将会出现什么情况呢?那个方法将会等待一个的到来这个行为叫阻塞accept()方法将会阻塞服务器线程直到一个呼叫到来当个连接处理完闭之后服务器退出任何的在队列中的呼叫将会被取消
所有的服务器都要有以下的基本的步骤
建立一个服务器socket并开始监听
使用accept()方法取得新的连接
建立输入和输出流
在已有的协议上产生会话
关闭客户端流和socket
回到第二步或者到第七步
关闭服务器socket