NGINX 不将标头传递给 websocket 端点

Gur*_*dar 5 nginx websocket

我正在尝试将 nginx 配置为执行身份验证和 websockets 的反向代理。它代理将请求传递给 apache (/auth/wsgi) 以进行身份​​验证 - 一旦成功,它就会将代理传递给 websocked 后端,这是在 tomcat 8 上基于 Java 的 websocket 端点。

location /basic/alerting/websocket {
    auth_request /auth/wsgi;
    proxy_pass http://backend.com:8080/websocket;
    proxy_http_version 1.1;
    proxy_set_header Upgrade "Websocket";
    proxy_set_header Connection "upgrade";
    proxy_set_header Host $http_host;
}
Run Code Online (Sandbox Code Playgroud)

apache 认证成功。但是,在后端 tomcat 上,我收到此错误:

12572237 [http-nio-8080-exec-10] 错误 org.springframework.web.socket.server.support.DefaultHandshakeHandler - handleWebSocketVersionNotSupported() 由于不支持的 WebSocket 版本,握手失败:null。支持的版本:[13]

失败似乎是因为后端期望没有通过的标头(“Sec-WebSocket-Version”)。我什至在 nginx 日志中看到:

2015/03/17 17:28:12 [调试] 20261#0:*718 http 代理标头:“Sec-WebSocket-Version: 13”

我需要在 nginx 配置中做什么吗?非常感谢您的帮助。

Adr*_*Ber 4

问题是 Nginx 没有传递所有“Sec-WebSocket-*”标头。那么方法AbstractHandshakeHandler.java#handleWebSocketVersionNotSupported()将抛出异常。

修复方法是 Nginx 复制所有“Sec-WebSocket-*”标头。请求标头:Sec-WebSocket-Extensions, Sec-WebSocket-Key, Sec-WebSocket-Protocol,Sec-WebSocket-Version 响应标头:Sec-WebSocket-Accept, Sec-WebSocket-Extensions,Sec-WebSocket-Protocol

要复制自定义 Nginx 标头,您需要执行以下操作:

proxy_set_header Sec-WebSocket-Protocol $http_sec_websocket_protocol
Run Code Online (Sandbox Code Playgroud)