我在tomcat上有一个Web应用程序 http://localhost:8080/WebApp/
http://localhost:8080/WebApp/
我已经配置了Apache 2(mod_proy),以便本地主机可以直接访问Web应用程序,而无需使用端口和名称:例如 http://localhost
http://localhost
<VirtualHost localhost:80> ProxyPreserveHost On ProxyPass / http://localhost:8080/WebApp/ ProxyPassReverse / http://localhost:8080/WebApp/ </VirtualHost>
index.html在上正确显示http://localhost。但是,如果servlet重定向:
@WebServlet(description = "...", urlPatterns = { "/login" }) public class LoginServlet extends HttpServlet { @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException { response.sendRedirect("a.html"); } }
我使用网址http://localhost/login-我被重定向到http://localhost/WebApp/a.html
http://localhost/login
http://localhost/WebApp/a.html
如何获得正确的重定向到http://localhost/a.html?
http://localhost/a.html
感谢Stuart及其到此博客的链接,我找到了一个解决方案: 在Apache后面反向代理Tomcat Web应用程序
解决方案:必须关闭ProxyPreserveHost!
原因:如果打开,则代理后端返回的响应头将包含“ localhost”或不带端口号(或80)的实际域。因此ProxyPassReverse模式不匹配(由于端口不同,并且如果使用了另一个域名,那么该域名也将不匹配)。
配置:
<VirtualHost localhost:80> ProxyPreserveHost Off ProxyPass / http://localhost:8080/WebApp/ ProxyPassReverse / http://localhost:8080/WebApp/ </VirtualHost>
但这仅通过http起作用,而不通过ajp起作用(我不知道为什么)。如果仍然要使用ajp,则可以使用以下解决方法- 让Apache在错误的重定向后执行另一个重定向:
<VirtualHost localhost:80> ProxyPass /WebApp ! ProxyPass / ajp://localhost:8009/WebApp/ ProxyPassReverse / ajp://localhost:8009/WebApp/ RedirectMatch 301 ^/WebApp/(.*)$ /$1 RedirectMatch 301 ^/WebApp$ / </VirtualHost>
ProxyPass /WebApp !需要使用该指令以将路径从mod_proxy中的进一步处理中排除(因为在重定向指令之前先评估代理指令)
ProxyPass /WebApp !
然后,RedirectMatch伪指令将开头的所有内容/WebApp/...分别重定向/WebApp到该URL,而不/WebApp以开头开头。
RedirectMatch
/WebApp/...
/WebApp
唯一的缺点是WebApp您的Web应用程序中不得有任何子文件夹命名
WebApp