
我們使用 nginx 作為具有客戶端憑證驗證的 gitblit 的反向代理。
給出的 nginx 配置如下。
server {
listen 443 ssl http2 default_server;
server_name _;
charset utf-8;
ssl_certificate D:\cert.pem;
ssl_certificate_key D:\key.pem;
ssl_session_cache off;
ssl_session_timeout 1h;
ssl_buffer_size 8192;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_client_certificate D:\Program\GitBlit\gitblit-1.8.0\data\certs\ca.pem;
ssl_verify_client optional;
ssl_prefer_server_ciphers on;
proxy_intercept_errors on;
location /git {
proxy_pass https://127.0.0.1:1111;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_ssl_verify off;
proxy_ssl_name $host;
proxy_ssl_server_name on;
proxy_ssl_session_reuse off;
}
}
導覽至 https://my_server/git 時,建立ssl_verify_client optional;
Web 用戶端需要客戶端憑證。但我收到 502 bad gateway 錯誤。 nginx 錯誤日誌如下,從 gitblit 沒有看到任何錯誤日誌。
2023/10/25 14:48:14 [error] 29404#2072: *43 peer closed connection in SSL handshake while SSL handshaking to upstream, client: 127.0.0.1, server: _, request: "GET /git/ HTTP/2.0", upstream: "https://127.0.0.1:1111/git/", host: "127.0.0.1"
我已經確保如果我導航到https://127.0.0.1:1111/git並提供相同的客戶端證書,身份驗證效果良好。 gitblit SSL 憑證由自簽章 CA 簽到 my_server(ssl_client_certificate 的 D:\Program\GitBlit\gitblit-1.8.0\data\certs\ca.pem)。
這是由於nginx無法辨識gitblit的SSL憑證還是無法透過客戶端憑證進行驗證所造成的?