技术解析

nginx 双重认证跳转错误
0
1975-02-21 15:09:15
idczone

我在 nginx 上使用了双向认证,配置如下:

server {
    listen       443 ssl;
    server_name  localhost;

    ssl_certificate    /etc/ssl/server.crt; # 配置证书位置
    ssl_certificate_key /etc/ssl/server.key; # 配置秘钥位置
    ssl_client_certificate /etc/ssl/client.crt; # 客户端公钥证书
    ssl_verify_client on; # 双向认证

    charset  utf-8;
    error_log /var/log/nginx/nginx_error.log;
    access_log /var/log/nginx/nginx_access.log;
    client_max_body_size 75M;
    root /usr/share/nginx/html/static;

    # 开启 gzip
    gzip on;
    # 启用 gzip 压缩的最小文件,小于设置值的文件将不会压缩
    gzip_min_length 1k;
    # gzip 压缩级别,1-10,数字越大压缩的越好,也越占用 CPU 时间
    gzip_comp_level 6;
    # 进行压缩的文件类型。javascript大带宽服务器 有多种形式。其中的值可以在 mime.types 文件中找到。
    gzip_types  application/x-httpd-php image/jpeg image/gif image/png font/ttf font/otf image/svg+xml text/plain text/css application/javascript application/json  application/x-javascript  application/xml text/javascript;
    # 是否在 http header 中添加 Vary: Accept-Encoding,建议开启
    gzip_vary on;
    # 禁用 IE 6 gzip
    gzip_disable "MSIE [1-6]\.";

    location / {
        proxy_pass http://web:8000/;
    }
}

想使用双向认证访问 443 然后跳转到 docker network 中的 web 的 8000 端口的

但在使用中跳转不成功,浏览器携带客户端证书访问时会跳转到 https://网关地址

如果把proxy_pass http://web:8000/;换为proxy_pass https://baidu.com;却可以跳转 所以我认为是使用了双向认证之后导致后面的跳转强制转向 https?

nginx_access.log 日志如下

- - [22/Jul/2020:07:51:57 +0000] "GET / HTTP/1.1" 200 84 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36"
- - [22/Jul/2020:07:51:58 +0000] "GET / HTTP/1.1" 200 84 "-" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36"
- - [22/Jul/2020:07:51:59 +0000] "GET /web HTTP/1.1" 303 227 "https://xxx:443/" "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.89 Safari/537.36"

所以我很好奇是否是双向认证的问题,是否双向认证之后后面的只能走 https,或者还是我在哪一方面的配置没有弄好?


我认为是浏览器的安全策略问题,因为百度的域名证书是合法的,所以跳过去没有触发安全限制。
你先尝试排除浏览器问题,例如:使用 curl 工具来访问测试,并使用 -k 选项来忽略证书安全验证。

使用 curl 如下:
```bash
命令
curl --cert ./client.crt --key ./client.key https://xxx:4443 -k
返回

```

我用 curl 测试了直接请求某个接口,可以返回 html,应该是你说的浏览器安全策略问题

已经解决,之前也遇到过这种情况,但这次没有联想起来
解决办法 https://www.escapelife.site/posts/73685720.html

推测和双向认证没有关系, 你 https 代理到 http 所以页面认为自己是 http, 所以页面中的跳转也会用 http, 结果就是把 http 的请求发到了 https 的 nginx 上. curl -k 不会走正常的 https 验证流程.
你在配置里加上
proxy_redirect http:// https://;
试试.

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服