Servlet过滤器简介
Web应用中可以使用过滤器对所有的访问和请求进行处理,Servlet过滤器处于客户端和目标资源的中间层。当服务器收到一个客户端请求,首先判断该请求是否与过滤器对象相关联,若是,则将该请求交由过滤器进行处理。处理完毕后,交给其他业务。
当所有业务处理完毕,需要将响应返回客户端时,容器同样会将响应交给过滤器进行处理,过滤器处理完毕后发回客户端。
注意,过滤器可能不止一个,如字符编码过滤器,IP访问过滤器等。容器会首先将客户端请求交给第一个过滤器处理,然后交给下一级过滤器,依此类推。返回时,从最后一级过滤器开始向前传递,最后由第一级过滤器将响应发回客户端。
过滤器代码结构
和Servlet相似,要使一个对象成为一个过滤器需要实现Filter接口。Filter API主要涉及三个接口:
-
Fileter 所有过滤器对象均要实现该接口
-
FilterChain 主要用于将请求或响应传递给下一过滤器对象,该接口由容器实现
-
FilterConfig 用于获取初始化参数信息,该接口由容器实现
过滤器代码结构如下:
import javax.servlet.*; import java.io.IOException; public class FilterEg implements Filter { public void init(FilterConfig config) throws ServletException {
} public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { chain.doFilter(request, response);
} public void destroy() {
}
}
-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
拦截指定IP的过滤器
过滤器代码
首先按照过滤器的代码结构编写如下过滤器代码:
IPFilter.
pacakge filter import javax.servlet.*; import java.io.IOException; import java.io.PrintWriter; public class IPFilter implements Filter { protected FilterConfig config; protected String IP; public void init(FilterConfig config) throws ServletException { this.config = config; IP = config.getInitParameter("IP");
} public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { String remoteIP = request.getRemoteAddr(); if(remoteIP.equals(IP)) {
response.setCharacterEncoding("gb2312");
PrintWriter out = response.getWriter();
out.print("25
">IP限制!");
}else { chain.doFilter(request, response);
}
} public void destroy() {
}
}
-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
-
29
-
30
-
31
-
32
-
33
-
34
-
35
-
36
过滤器配置
和Servlet类似,过滤器使用前需要进行配置。上面代码中限制IP的信息就是在这里读取的。
<web-app xmlns="" xmlns:xsi="" xsi:schemaLocation=" /web-app_3_1.xsd" version="3.1"> <filter> <filter-name>IPFilterfilter-name> <filter-class>filter.IPFilterfilter-class> <init-param> <param-name>IPparam-name> <param-value>127.0.0.1param-value> init-param> filter> <filter-mapping> <filter-name>IPFilterfilter-name> <url-pattern>/*url-pattern> filter-mapping> web-app>
-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
filter-name,filter-class均与Servlet配置类似,具体含义可以参考一个简单的Servlet程序中的xml配置。
9~12行设置初始化参数,代码中init()方法就是读取这里的IP参数。这里把IP设为127.0.0.1来演示过滤本机的访问。
16行,指明过滤器对哪些访问路径有效,/*表明对所有请求有效。
程序部署运行
不妨用新手推荐JSP+JavaBean+Servlet MVC模式用户注册模块中的代码。给注册模块加上一个IP过滤器。
在webapps\reg\WEB-INF\classes目录下新建filter文件夹。将上面的IPFilter.java编译放入filter文件夹中。
在\WEB-INF\路径下的web.xml中加入过滤器的配置:
<web-app xmlns="" xmlns:xsi="" xsi:schemaLocation=" /web-app_3_1.xsd" version="3.1"> <servlet> <servlet-name>SignInServletservlet-name> <servlet-class>service.SignInServletservlet-class> servlet> <servlet-mapping> <servlet-name>SignInServletservlet-name> <url-pattern>/RegServleturl-pattern> servlet-mapping> <filter> <filter-name>IPFilterfilter-name> <filter-class>filter.IPFilterfilter-class> <init-param> <param-name>IPparam-name> <param-value>127.0.0.1param-value> init-param> filter> <filter-mapping> <filter-name>IPFilterfilter-name> <url-pattern>/*url-pattern> filter-mapping> web-app>
-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-
27
-
28
15~26行为我们加入的过滤器配置。
好了,接下来运行Tomcat,打开浏览器输入
得到以下页面:
过滤器拦截了我们本机的IP。
接下来在web.xml文件中,将127.0.0.1中的IP改成另外的地址。
重启服务器,打开浏览器输入
页面恢复正常:
阅读(1502) | 评论(0) | 转发(0) |