NanoHTTPD是个很简单的http服务器,简单到只有一个java文件,主要原理是用ServerSocket接受请求,对每一个请求的Socket创建一个线程去处理(HTTPSession),线程内保存Socket,用Properties保存切割出来的head信息和url后的参数信息,serveFile方法处理是返回异常页面,还是响应请求,返回请求的页面,代码有点乱...
Properties是继承自HashTable是个同步的Map,一个请求用一个线程处理,感觉不需要同步,却用了同步。
创建线程的代码如下:
public NanoHTTPD( int port ) throws IOException
{
myTcpPort = port;
final ServerSocket ss = new ServerSocket( myTcpPort );
Thread t = new Thread( new Runnable()
{
public void run()
{
try
{
while( true )
new HTTPSession( ss.accept());
}
catch ( IOException ioe )
{}
}
});
t.setDaemon( true );
t.start();
}
HTTPSession内保存了Socket的引用。
NanoHTTPD是一款轻量级的HTTP服务器实现,仅由一个Java文件组成。其核心功能包括通过ServerSocket接收客户端请求,并为每个请求创建独立线程进行处理。线程内部维护Socket连接,并使用Properties类来存储请求头信息及URL参数。

3500

被折叠的 条评论
为什么被折叠?



