代碼github地址:https://github.com/LynHB/ProjectA/blob/master/src/main/java/study/http/HttpServerDemo.java
1. HttpServer類說明
1.1 介紹
該類實現(xiàn)了一個簡單的HTTP服務(wù)器途事。HttpServer被綁定到一個IP地址和端口號纺棺,并偵聽這個地址上來自Client的傳入TCP連接。子類HttpsServer實現(xiàn)了一個處理HTTPS請求的服務(wù)器。
為了處理請求返干,一個或多個HttpHandler
對象必須與服務(wù)器相關(guān)聯(lián)升略。每個這樣的HttpHandler
都注冊了一個根URI路徑
,該路徑表示應(yīng)用程序或服務(wù)在該服務(wù)器上的位置累提。處理程序到HttpServer
的映射由HttpContext
對象封裝。HttpContexts
是通過調(diào)用createContext(String磁浇,HttpHandler)
來創(chuàng)建的斋陪。任何找不到處理程序的請求都將以404響應(yīng)被拒絕。線程的管理可以通過提供Executor對象在此對象外部完成置吓。如果沒有提供无虚,則使用默認提供。
1.2 常用方法
方法名 | 返回類型 | 方法說明 |
---|---|---|
bind(InetSocetAddr addr, int backlog) | void | 給未進行IP和端口綁定的HttpServer進行綁定衍锚,并可設(shè)置backlog |
create() | HttpServer | 創(chuàng)建一個HttpServer實例友题,但是未進行初始化和未綁定對應(yīng)本地地址和端口,需要結(jié)合bind(InetSocetAddr addr, int backlog)使用 |
create(InetSocetAddr addr, int backlog) | HttpServer | 創(chuàng)建對應(yīng)實例戴质,綁定IP和端口信息度宦,并指定backlog數(shù) |
createContext(String path,HttpHandler handle) | HttpContext | 通過URI綁定對應(yīng)的handle控制器,創(chuàng)建HTTP上下文告匠。 |
getAddress() | InetSocketAddress | 返回HttpServer相關(guān)綁定信息 |
getExecutor() | Executor | 獲取線程池對象,通過setExecutor(Executor)設(shè)置斗埂,如果沒設(shè)置返回null |
start | void | 在新的后臺線程中啟動此服務(wù)器。 |
stop | void | 通過關(guān)閉監(jiān)聽套接字并禁止處理任何新的exchange來停止此服務(wù)器凫海。 |
1.3 簡單的Demo
即可使用localhost:8888 進行訪問呛凶。
/*
實現(xiàn)HttpHandle處理Http請求
*/
public class HttpServerDemo implements HttpHandler {
public static void main(String[] args) throws IOException {
// 綁定本地指定8888
HttpServer httpServer = HttpServer.create(new InetSocketAddress(InetAddress.getByName("0.0.0.0"),8888),0);
// 設(shè)置上下文信息
httpServer.createContext("/",new HttpServerDemo());
// 啟動服務(wù)
httpServer.start();
}
@Override
public void handle(HttpExchange httpExchange) throws IOException {
String response = httpExchange.getRequestURI()+":test message";
httpExchange.sendResponseHeaders(200, 0);
OutputStream os = httpExchange.getResponseBody();
os.write(response.getBytes(StandardCharsets.UTF_8));
os.close();
}
}