仅供参考:我正在运行带有 IIS 7.5 和 Apache Tomcat 5.5 的 Windows Server 2008 R2。IIS 通过 AJP 连接器 1.3 版与 Tomcat 对话。Tomcat 启用了 SSL;因此,该网站同时启用了 HTTP 和 HTTPS 流量。我在 web.xml 文件中也有一个安全约束,可以通过 url 模式重定向以强制执行特定文件的 HTTPS 流量。
说了这么多,我创建了一个 servlet 过滤器,它应该将 https 重定向到 http。不幸的是,当我重新启动 tomcat 服务器并输入登录页面时,我收到以下错误:
您要查找的资源已被删除、名称已更改或暂时不可用。
我在 Eclipse 中创建了该类并将其导出为名为 RedirectToHTTP.jar 的 JAR 文件,并将该文件放在应用程序的 WEB-INF/lib 目录中,而不是放在 Tomcat 安装目录中。
我不知道问题出在哪里,如果有任何反馈,我将不胜感激。谢谢你。
更新
根据评论中的建议,我检查了日志文件,发现与我的过滤器相关的错误
-- 异常启动过滤器redirectFilter
java.lang.UnsupportedClassVersionError:myfilterpkg/RedirectToHTTPFilter:不支持的major.minor 51.0版。
我用 JRE 1.7 编译了过滤器。我认为 Tomcat 可能使用的是较低版本的 JRE。这可能是问题吗?
以下是 web.xml 文件中的相关数据:
<filter>
<filter-name>UTF8Encoder</filter-name>
<filter-class>com.remedy.arsys.support.UTF8EncodingFilter</filter-class>
<init-param>
<param-name>Param1</param-name>
<param-value>0</param-value>
</init-param>
</filter>
<filter>
<filter-name>redirectFilter</filter-name>
<filter-class>myfilterpkg.RedirectToHTTPFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>UTF8Encoder</filter-name>
<servlet-name>*.jsp</servlet-name>
</filter-mapping>
<filter-mapping>
<filter-name>redirectFilter</filter-name>
<url-pattern>/index.jsp</url-pattern>
</filter-mapping>
这是Java类:
package myfilterpkg;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
@SuppressWarnings("unused")
public class RedirectToHTTPFilter implements Filter {
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
if ((request instanceof HttpServletRequest) && (response instanceof HttpServletResponse)) {
String redirectTarget = ((HttpServletRequest)request).getRequestURL().toString().replaceFirst("https", "http");
if(request.isSecure()) {
((HttpServletResponse)response).sendRedirect(redirectTarget);
}
else {
chain.doFilter(request, response);
}
}
}
@Override
public void destroy() {
}
@Override
public void init(FilterConfig arg0) throws ServletException {
}
}