- JSP 基础教程
- JSP - 首页
- JSP - 概述
- JSP - 环境搭建
- JSP - 架构
- JSP - 生命周期
- JSP - 语法
- JSP - 指令
- JSP - 动作
- JSP - 隐式对象
- JSP - 客户端请求
- JSP - 服务器响应
- JSP - HTTP 状态码
- JSP - 表单处理
- JSP - 编写过滤器
- JSP - Cookie 处理
- JSP - 会话跟踪
- JSP - 文件上传
- JSP - 处理日期
- JSP - 页面重定向
- JSP - 访问计数器
- JSP - 自动刷新
- JSP - 发送邮件
- 高级 JSP 教程
- JSP - 标准标签库
- JSP - 数据库访问
- JSP - XML 数据
- JSP - JavaBean
- JSP - 自定义标签
- JSP - 表达式语言
- JSP - 异常处理
- JSP - 调试
- JSP - 安全
- JSP - 国际化
- JSP 有用资源
- JSP - 常见问题解答
- JSP - 快速指南
- JSP - 有用资源
- JSP - 讨论
JSP - 过滤器
在本章中,我们将讨论 JSP 中的过滤器。Servlet 和 JSP 过滤器是 Java 类,可以在 Servlet 和 JSP 编程中用于以下目的:
拦截来自客户端的请求,在它们访问后端资源之前。
在服务器将响应发送回客户端之前,操纵服务器的响应。
规范建议了各种类型的过滤器:
- 身份验证过滤器
- 数据压缩过滤器
- 加密过滤器
- 触发资源访问事件的过滤器
- 图像转换过滤器
- 日志记录和审计过滤器
- MIME 类型链过滤器
- 标记化过滤器
- 转换 XML 内容的 XSL/T 过滤器
过滤器部署在部署描述符文件web.xml中,然后映射到应用程序部署描述符中的 servlet 或 JSP 名称或 URL 模式。部署描述符文件 web.xml 可以在<Tomcat 安装目录>\conf目录中找到。
当 JSP 容器启动您的 Web 应用程序时,它会创建您在部署描述符中声明的每个过滤器的实例。过滤器按其在部署描述符中声明的顺序执行。
Servlet 过滤器方法
过滤器只是一个实现javax.servlet.Filter接口的 Java 类。javax.servlet.Filter 接口定义了三个方法:
| 序号 | 方法及描述 |
|---|---|
| 1 | public void doFilter (ServletRequest, ServletResponse, FilterChain) 每次由于客户端对链末端资源的请求而通过链传递请求/响应对时,容器都会调用此方法。 |
| 2 | public void init(FilterConfig filterConfig) Web 容器调用此方法以指示过滤器已投入使用。 |
| 3 | public void destroy() Web 容器调用此方法以指示过滤器即将停止使用。 |
JSP 过滤器示例
以下示例显示了如何每次访问任何 JSP 文件时打印客户端的 IP 地址和当前日期时间。此示例将使您对 JSP 过滤器有一个基本的了解,但是您可以使用相同的概念编写更复杂的过滤器应用程序:
// Import required java libraries
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
// Implements Filter class
public class LogFilter implements Filter {
public void init(FilterConfig config) throws ServletException {
// Get init parameter
String testParam = config.getInitParameter("test-param");
//Print the init parameter
System.out.println("Test Param: " + testParam);
}
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws java.io.IOException, ServletException {
// Get the IP address of client machine.
String ipAddress = request.getRemoteAddr();
// Log the IP address and current timestamp.
System.out.println("IP "+ ipAddress + ", Time "+ new Date().toString());
// Pass request back down the filter chain
chain.doFilter(request,response);
}
public void destroy( ) {
/* Called before the Filter instance is removed
from service by the web container*/
}
}
以通常的方式编译LogFilter.java并将LogFilter.class文件放入<Tomcat 安装目录>/webapps/ROOT/WEB-INF/classes。
Web.xml 中的 JSP 过滤器映射
过滤器被定义,然后映射到 URL 或 JSP 文件名,这与 Servlet 定义并映射到web.xml文件中的 URL 模式的方式非常相似。在部署描述符文件web.xml中创建以下过滤器标签条目
<filter>
<filter-name>LogFilter</filter-name>
<filter-class>LogFilter</filter-class>
<init-param>
<param-name>test-param</param-name>
<param-value>Initialization Paramter</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>LogFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
以上过滤器将应用于所有 servlet 和 JSP,因为我们在配置中指定了/*。如果只想将过滤器应用于少数 servlet 或 JSP,则可以指定特定的 servlet 或 JSP 路径。
现在尝试调用任何 servlet 或 JSP,您将在 Web 服务器日志中看到生成的日志。您可以使用Log4J 记录器将上述日志记录到单独的文件中。
使用多个过滤器
您的 Web 应用程序可以定义几个具有特定用途的不同过滤器。假设您定义了两个过滤器AuthenFilter和LogFilter。其余过程将保持如上所述,除了您需要创建不同的映射,如下所示:
<filter>
<filter-name>LogFilter</filter-name>
<filter-class>LogFilter</filter-class>
<init-param>
<param-name>test-param</param-name>
<param-value>Initialization Paramter</param-value>
</init-param>
</filter>
<filter>
<filter-name>AuthenFilter</filter-name>
<filter-class>AuthenFilter</filter-class>
<init-param>
<param-name>test-param</param-name>
<param-value>Initialization Paramter</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>LogFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>AuthenFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
过滤器应用顺序
web.xml 中的 filter-mapping 元素的顺序决定了 Web 容器将过滤器应用于 servlet 或 JSP 的顺序。要反转过滤器的顺序,您只需要反转web.xml文件中 filter-mapping 元素的顺序即可。
例如,上面的示例将首先应用 LogFilter,然后将其应用于任何 servlet 或 JSP;以下示例将反转顺序:
<filter-mapping> <filter-name>AuthenFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <filter-mapping> <filter-name>LogFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>