【发布时间】:2025-12-28 19:30:11
【问题描述】:
我已成功将 Apache (2.4.7) 配置为需要客户端证书,并且 - 作为反向代理 - 将证书中的信息转发到 Tomcat 8 服务器。
但是,当尝试使用 Spring Boot 完成相同的操作时,它会失败
The proxy server received an invalid response from an upstream server
The proxy server could not handle the request GET /myapp
并返回 HTTP 502 错误代码。
相关的、有效的 Tomcat 配置是:
<Connector SSLEnabled="true" clientAuth="want" keyAlias="myalias"
keystoreFile="mystore.jks" keystorePass="mypassword" maxThreads="150"
port="8443" protocol="HTTP/1.1" scheme="https" secure="true"
sslProtocol="TLS" truststoreFile="mystore.jks" truststorePass="mypassword"/>
Spring Boot application.properties 文件中不起作用的相关部分:
server.context-path=/myapp
server.port=8443
server.ssl.enabled=true
server.use-forward-headers=true
server.ssl.protocol=TLS
server.ssl.client-auth=need
server.ssl.key-alias=myalias
server.ssl.key-store=/path/to/mykeystore.jks
server.ssl.key-store-password=mypassword
server.ssl.key-password=mypassword
server.ssl.trust-store=/path/to/mykeystore.jks
server.ssl.trust-store-password=mypassword
server.tomcat.remote-ip-header=x-forwarded-for
server.tomcat.port-header=x-forwarded-port
注意,当直接访问应用程序(即请求https://myapp.company.tld:12345/myapp)时,它可以正常工作,但使用反向代理(即https://proxy-load-balancer.company.tld:12345/myapp)会引发上述错误。
端口差异(12345 与配置的 8443)是由于中间 Docker 层:反向代理和应用程序都在容器中运行,并且它们的开放端口(Apache 为 443,Tomcat/Spring Boot 为 8443)被映射到不同的端口,即 12345。
【问题讨论】:
-
如果 Apache 的反向代理请求客户端证书,为什么要在 Tomcat 级别配置
truststoreFile?。
标签: apache tomcat spring-boot reverse-proxy ssl-client-authentication