我们在Java培训学习中学到Javaweb的时候会涉及到页面登录的制作,登录页面的制作在Java培训课程中式比较麻烦的,那么这个时候我们就要用到filter让他变的简单一些了。
1.提出问题
1、我们在访问后台很多页面时都需要登录,只有登录的用户才能查看这些页面,我们需要在每次请求的时候都检查用户是否登陆,这样做很麻烦,有没有一种方法可以在我们请求之前就帮我们做这些事情。有!
2、我们web应用经常会接收中文字符,由于可能导致中文乱码,我们每次都需要在方法的开始使用request.setCharacterEncoding(“utf-8”);能不能在我们要获取参数值直接就可以自己设置好编码呀。能!
这种问题的解决方法我们想到了一种办法。那就是在每次请求之前我们先将它拦截起来,当我们设置好一切东西的时候,再将请求放行。类似与我们地铁站的检票系统。每个人进站的时候必须刷卡,扣完钱后才可以进站坐车。
web中也有这个机制,我们叫做过滤器。
就是我们接下来学习的filter
2.Filter简介
2.1什么是filter
1)Filter(过滤器) 的基本功能是对 Servlet 容器调用 Servlet (JSP)的过程进行拦截, 从而在 Servlet 处理请求前和Servlet响应请求后实现一些特殊的功能。
2)在 Servlet API 中定义了三个接口类来开供开发人员编写 Filter 程序:Filter, FilterChain, FilterConfig
3)Filter 程序是一个实现了 Filter 接口的 Java 类,与 Servlet 程序相似,它由 Servlet 容器进行调用和执行
4)Filter 程序需要在 web.xml 文件中进行注册和设置它所能拦截的资源:Filter 程序 可以拦截 Jsp, Servlet, 静态图片文件和静态 html 文件
2.2 filter的运行原理是什么
这个Servlet过滤器就是我们的filter
1)当在 web.xml 中注册了一个 Filter 来对某个 Servlet 程序进行拦截处理时,这个 Filter 就成了 Tomcat与该 Servlet 程序的通信线路上的一道关卡,该 Filter 可以对 Servlet 容器发送给 Servlet 程序的请求和 Servlet 程序回送给 Servlet 容器的响应进行拦截,可以决定是否将请求继续传递给 Servlet 程序,以及对请求和相应信息是否进行修改
2)在一个 web 应用程序中可以注册多个 Filter 程序,每个 Filter 程序都可以对一个或一组 Servlet 程序进行拦截。
3)若有多个 Filter 程序对某个 Servlet 程序的访问过程进行拦截,当针对该 Servlet 的访问请求到达时,web 容器将把这多个 Filter 程序组合成一个 Filter 链(过滤器链)。Filter 链中各个 Filter 的拦截顺序与它们在应用程序的 web.xml 中映射的顺序一致
3.Filter-helloword
3.1 Hello-World
filter编写三步骤:
1、创建filter实现类,实现filter接口
2、编写web.xml配置文件,配置filter的信息
3、运行项目,可以看到filter起作用了
代码:
//1、filter实现类 public class MyFirstFilter implements Filter{ @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(“dofilter方法”); }
@Override public void destroy() { System.out.println(“销毁方法…”); }
} //2、web.xml配置 <filter> <filter-name>MyFirstFilter</filter-name> <filter-class>com.atguigu.filter.MyFirstFilter</filter-class> </filter> <filter-mapping> <filter-name>MyFirstFilter</filter-name> <url-pattern>/index.jsp</url-pattern> </filter-mapping> //3、运行程序,发现index.jsp页面不显示了,后台输出“dofilter方法”,说明我们写的filter执行了。
|
3.2 filter的生命周期
1)在服务器启动时,filter被创建并初始化,执行init()方法。
2)请求通过filter时执行doFilter方法。
3)服务器停止时,调用destroy方法。
3.3 filter放行请求
我们发现,刚才的filter配置好后,index.jsp页面没法访问了,访问这个页面的时候filter 的dofilter方法被调用了。说明dofilter这个方法拦截了我们的请求。
我们如何显示页面呢。也就是如何将请求放行呢。我们观察发现有个filterChain被传入 到这个方法里面了。filterChain里面有个doFilter()方法。
放行请求只需要调用filterChain的dofilter方法。
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { System.out.println(“dofilter方法”); chain.doFilter(request, response);//放行请求 } |
3.4 filter拦截原理
我们在chain.doFilter(request, response);方法后也写一句话,System.out.println
(“doFilter方法执行后…”),在index.jsp页面也写上jsp脚本片段,输出我是jsp页面。运 行程序发现控制台输出了这几句话:
dofilter方法…
我是jsp页面
dofilter方法后…
我们不难发现filter的运行流程
4.FilterChain
doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
在doFilter执行之前,由容器将filterChain对象传入方法。调用此对象的.doFilter()方法可以将请求放行,实际上是执行过滤器链中的下一个doFilter方法,但是如果只有一个过滤器,则为放行。
5.FilterConfig
FilterConfig类似ServletConfig,是filter的配置信息对象。FilterConfig对象具有以下方法。
getFilterName():获取当前filter的名字。获取的是在web.xml中配置的filter-name的值
getInitParameter(String name):获取filter的初始化参数。在web.xml中配置
getInitParameterNames():获取filter初始化参数名的集合。
getServletContext():获取当前web工程的ServletContext对象。
6.Filter的url-pattern
url-pattern是配置filter过滤哪些请求的。主要有以下几种配置:
web.xml中配置的/都是以当前项目路径为根路径的
1)精确匹配:
/index.jsp /user/login 会在请求/index.jsp、/user/login的时候执行过滤方法
2)路径匹配:
/user/* /* 凡是路径为/user/下的所有请求都会被拦截,/*表示拦截系统的所有请求,包括静态资源文件。
3)扩展匹配:
*.jsp *.action 凡是后缀名为.jsp .action 的请求都会被拦截。
注意:/login/*.jsp 这种写法是错误的,只能是上述三种的任意一种形式。不能组合新形式。
*jsp也是错误的,扩展匹配必须是后缀名
4)多重url-pattern配置
上面的三种形式比较有局限性,但是url-pattern可以配置多个,这样这三种组合基本就能解决所有问题了
7.多Filter执行顺序
如果同一个资源有多个filter都对其拦截,则拦截的顺序是按照web.xml中配置的顺序进行的
执行流程图如下
请求总是在处理之后再回来执行doFilter之后的方法。
想要了解跟多关于Java培训课程内容欢迎关注尚硅谷Java培训,尚硅谷除了这些技术文章外还有免费的高质量Java培训课程视频供广大学员下载。
上一篇: 大数据专业毕业为什么还要参加大数据培训
下一篇: Java培训课程之Listener