## 1. 什麼是Http2.0 HTTP/2.0,通常簡稱為HTTP/2,是一種用於傳輸超文本(例如網頁和資源文件)的網路協議。它是HTTP/1.1的繼任者,旨在提高性能和效率,以適應現代Web應用的需求。HTTP/2的主要特點包括以下幾點: 1. **多路復用(Multiplexing)**:H ...
1. 什麼是Http2.0
HTTP/2.0,通常簡稱為HTTP/2,是一種用於傳輸超文本(例如網頁和資源文件)的網路協議。它是HTTP/1.1的繼任者,旨在提高性能和效率,以適應現代Web應用的需求。HTTP/2的主要特點包括以下幾點:
- 多路復用(Multiplexing):HTTP/2允許多個請求和響應同時在單個連接上傳輸,而不像HTTP/1.1一樣需要建立多個連接。這消除了HTTP/1.1中的隊頭堵塞問題,提高了性能和響應速度。
- 頭部壓縮(Header Compression):HTTP/2使用HPACK演算法對HTTP頭部進行壓縮,減少了頭部傳輸的數據量,從而降低了帶寬消耗和載入時間。
- 二進位傳輸(Binary Protocol):HTTP/2使用二進位協議來傳輸數據,而不是HTTP/1.1中的文本協議。這使得數據傳輸更加高效,減少瞭解析複雜性。
- 伺服器推送(Server Push):HTTP/2允許伺服器在客戶端請求一個資源時主動推送相關資源,從而減少了客戶端的等待時間和請求次數,提高了性能。
- 流量控制(Flow Control):HTTP/2引入了更精細的流量控制機制,允許客戶端和伺服器更好地管理數據流量,防止過載。
- 請求優先順序(Priority):HTTP/2支持請求優先順序,允許指定哪些請求應該優先處理,以提高用戶體驗。
2. 代碼實戰
2.1 生成證書
java內置keytool可以生成自簽名證書,使用keytool之前需要確保你配置了JAVA_HOME或者你在keytool目錄下運行該命令,並輸入兩次密碼。
keytool -genkey -storetype PKCS12 -keyalg RSA -keysize 2048 -keystore keystore.p12 -dname "CN=li, OU=zelin, O=zelin, L=bj, ST=bj, C=CN"
運行該命令後會在當前路徑生成一個keystore.p12
證書文件,將該文件放進SpringBoot項目中的resources目錄下。
2.2 配置項目
在application.properties
中配置以下選項。
# 配置http2
server.ssl.key-store=classpath:keystore.p12
server.ssl.key-password=替換成你輸入的密碼
server.ssl.key-store-password=替換成你輸入的密碼
server.http2.enabled=true
3. 驗證是否使用HTTP2
打開瀏覽器的F12
開發控制台,
查看請求標頭是否使用HTTP2
4. 擴展
由於項目使用HTTP2,預設只能使用HTTPS進行訪問,所以需要配置HTTP的流量轉發到HTTPS的埠。
建議使用NGINX進行配置,不要在項目進行硬性配置。以下是一個NGINX的配置示例
server {
listen 80;
server_name your_domain.com;
# 重定向所有HTTP請求到HTTPS
return 301 https://$host$request_uri;
}
server {
listen 443 ssl;
server_name your_domain.com;
# 指定SSL證書和密鑰文件的路徑
ssl_certificate /path/to/your_ssl_certificate.crt;
ssl_certificate_key /path/to/your_ssl_certificate_key.key;
# 添加其他SSL配置選項,如SSL協議版本和密碼套件
# 在這裡配置您的HTTPS伺服器塊
# 例如:
location / {
# 配置您的應用程式或代理設置
}
}