今天学习到了过滤器的使用,在这里总结一下!过滤器在浏览器和服务器中间,相当于一层筛子,只把符合条件的请求传递到服务器层.
过滤器的作用:(生命周期:服务器的启动到服务器的关闭)
- 把服务器接收到的请求和相应给浏览器的资源进行统一的管理!
- 保护servlet能接受正常的请求
具体案例:
- 统一编码格式设置。
- session管理
- 权限管理
- 资源管理
过滤器所处的位置:
使用:第一步,需要创建一个普通的java实体类然后继承Fileter接口,在覆写接口中的方法.
@Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("初始化)");//服务器启动就立即执行,资源初始化.
}
@Override
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
System.out.println("执行");//拦截请求方法,在这里可以管理资源 注意:这里需要对请求进行放行
//符合条件的浏览器请求放行
chain.doFilter(request, response);
}
@Override
public void destroy() {
System.out.println("销毁");//服务器关闭执行
}
第二步,需要在web.xml中配置过滤器
<filter>
<filter-name>myFilter</filter-name> <!-- 过滤器名字-->
<filter-class>com.wzy.filter.MyFilter</filter-class> <!-- 过滤器联系的class名字 配置的时候要记着ctrl+单击,查看一下是否能跳转到具体的class中,如果可以跳转那么没问题!如果不行那么检查com.wzy.filter.MyFilter这一部分的代码!-->
</filter>
<filter-mapping>
<filter-name>myFilter</filter-name>
<url-pattern>/*</url-pattern>
<!--
<url-pattern>这里的 /* 是对有所的请求进行过滤! (相当于小区门口的保安人员!属于第一级过滤)
如果想要设置多个过滤器,那么改成 *.Type (--这里的Type是后缀的统称.只对Type这种类型的请求进行过滤!相当于小区每栋楼的管理人员!属于第二级过滤,)
要是想要过滤具体的servlet请求就需要将url-pattern设置成 /servlet名字.Type 就可以保护servlet!(相当于自己养的看门狗!属于第三级过滤)
-->
</filter-mapping>
执行顺序:
- 浏览器发起请求到服务器,服务器接收到请求后,根据URI信息在web.xml中找到对应的过滤器执行doFilter方法,该方法对此次请求进行处理后如果符合要求则放行。
- 放行后如果还有符合要求的过滤则继续进行过滤,找到执行对应的servlet进行请求处理。servlet对请求处理完毕后,也就service方法结束了。还需继续返回相应的doFilter方法继续执行。
总结:
过滤器就是先声明一个class,然后修改web.xml中的代码.主要涉及到的标签有:
<filter>
<filter-name>俺的名字</filter-name>
<filter-class>class类的名字</filter-class>
</filter>
<filter-mapping>
<filter-name>俺的名字(和上边一致)</filter-name>
<url-pattern>/*</url-pattern> <!-- 需要过滤那些东西-->
</filter-mapping>