0

我的 web.xml 中有这个配置

<servlet>
    <servlet-name>welcome</servlet-name>
    <servlet-class>com.me.util.WelcomeServletPublic</servlet-class>
    <init-param>
        <param-name>redirect</param-name>
        <param-value>/login/login.action</param-value>


    </init-param>
    </servlet>
<welcome-file-list>
        <welcome-file>welcome</welcome-file>
    </welcome-file-list>

在我的开发环境中,这个重定向工作得很好。现在所有东西都移到了我的生产环境中,重定向不起作用。

应该发生的事情是当您转到https://mydomain.com时,它会将您重定向到https://mydomain.com/login/login.action

什么是它重定向到https://login/login.action,它失去了域名

现在让我想知道哪里出了问题的最重要的事情是我的生产服务器是如何配置的。

在前门,我有运行 mod_jk 的 apache。有两个监听器,80 和 443。80 监听器配置了 mod_rewrite 以获取 http:// url 并将其重写为 https://。然后 443 侦听器接收请求并将其转储到 mod_jk,mod_jk 通过端口 8009 将请求重定向到 tomcat。tomcat 正在运行大约 6 个应用程序,每个应用程序都在自己的虚拟主机中。

我从来没有做过这样的配置,也不知道在哪里解决这个问题。我知道我不能将前面的 / 从 servlet 中的 url 中取出,因为如果有人访问 mydomain.com/users,它会将他们重定向到 mydomain.com/users/login/login.action,所以我真的不不知道从哪里开始。

这是我的 apache vhost 配置

    <VirtualHost 10.99.10.30:80>
        ServerName boardingsurvey.mydomain.org
        ServerAlias boardingsurvey.mydomain.org

        RewriteEngine On
        RewriteCond %{HTTPS} off
        RewriteRule (.*) https://%{HTTP_HOST}%{REQUEST_URI}
</VirtualHost>

<VirtualHost 10.99.10.30:443>
        ServerName boardingsurvey.mydomain.org
        ServerAlias boardingsurvey.mydomain.org
        DocumentRoot /var/www/vhosts/bss
        <Directory "/var/www/vhosts/bss">
                AllowOverride None
                Options Indexes FollowSymLinks
                Order allow,deny
                Allow from all
        </Directory>

        JkMount /* bss

        SSLEngine on
        SSLCipherSuite ALL:!ADH:!EXP56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP:+eNULL
        SSLCertificateFile /etc/apache2/ssl/ssl.crt
        SSLCertificateKeyFile /etc/apache2/ssl/ssl.key
        SSLCertificateChainFile /etc/apache2/ssl/intermediate.crt
</VirtualHost>


~
4

2 回答 2

2

发生这种情况的完整解释如下。

通过在重定向中添加额外的“/”,用于重定向的路径是 //login/login.action

这种类型的 URL 通常被称为“协议相对”URL,尽管正确的名称是“网络路径引用”。请参阅 RFC 3986。第 4.2 节。用作重定向的绝对 URL 是使用 <current-protocol>:<network-path reference> 生成的,在这种情况下会给出http://login/login.action

当您想指定主机但不知道用户代理使用的是 http 还是 https 并且传递给重定向的字符串将是“//host:port/contextpath/”时,网络路径引用通常用于生成重定向servletpath/pathinfo”。对 Servlet 规范 3.0 和更早版本的严格解释不允许使用网络路径引用进行重定向。Servlet 3.1 将允许它们,而 Tomcat 7 的最新版本也允许它们用于 Servlet 3.0 和更早版本。

于 2012-05-07T19:02:28.000 回答
0

https://stackoverflow.com/users/1299005/mark-thomas上面的评论是问题所在。我的welcomeservlet 在url 中添加了一个额外的/,这就是我重写的原因。

于 2012-05-07T17:40:46.167 回答