背景
對於NGINX 的HTTPS 配置,通常情況下我們只需要實現服務端認證就行,因為瀏覽器內置了一些受信任的證書頒發機構(CA),服務器端只需要拿到這些機構頒發的證書並配置好,瀏覽器會自行校驗證書的可用性並透過SSL 進行通訊加密。
但特殊情況下我們也需要對客戶端進行驗證,只有受信任的客戶端才能使用服務接口,此時我們就需要啟用雙向認證來達到這個目的,只有 當客戶端請求帶了可用的證書才能調通服務端介面 。
CA 與自簽名
CA 是權威機構才能做的,並且如果該機構達不到安全標準就會被瀏覽器廠商“封殺”,前不久的沃通、StartSSL 就被 Mozilla、Chrome 封殺了。不過這並不影響我們進行雙向認證配置,因為我們是自建CA 的..
為了方便,我們就在NGINX 的目錄下進行證書相關製作:
cd /etc/nginx mkdir sslcd ssl
製作CA 私鑰
openssl genrsa -out ca.key 2048
製作CA 根憑證(公鑰)
openssl req -new -x509 -days 3650 -key ca.key -out ca.crt
注意:
Common Name 可以隨意填寫
其他需要填寫的資訊為了避免有誤,都填寫 . 吧
伺服器端憑證
生成請openssl genrsa -out server.pem 1024 openssl rsa -in server.pem -out server.key
和服務端憑證類似:
注意:
openssl req -new -key server.pem -out server.csr
server { listen 443 ssl; server_name usb.dev; access_log off; ssl on; ssl_certificate /etc/nginx/ssl/server.crt; ssl_certificate_key /etc/nginx/ssl/server.key; ssl_client_certificate /etc/nginx/ssl/ca.crt; ssl_verify_client on; location / { proxy_pass http://backend$request_uri; } }
service nginx reload
127.0.0.1 usb.dev
curl --insecure --key client.key --cert client.crt 'https://usb.dev'
<html> <head><title>400 No required SSL certificate was sent</title></head> <body bgcolor="white"> <center><h1>400 Bad Request</h1></center> <center>No required SSL certificate was sent</center> <hr><center>nginx/1.11.0</center> </body> </html>