发表于: 2017-07-01 20:27:16

1 1114


今天完成的事情:学习filter

Filter就像一个一个哨卡,用户的请求需要经过Filter,并且可以有很多个。

Filter概念

简介

       Filter也称之为过滤器,它是Servlet技术中最实用的技术,Web开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 html 文件等进行拦截,从而实现一些特殊的功能。例如实现URL级别的权限访问控制、过滤敏感词汇、压缩响应信息等一些高级功能。

它主要用于对用户请求进行预处理,也可以对HttpServletResponse进行后处理。使用Filter的完整流程:Filter对用户请求进行预处理,接着将请求交给Servlet进行处理并生成响应,最后Filter再对服务器响应进行后处理。


功能

       在HttpServletRequest到达 Servlet 之前,拦截客户的HttpServletRequest 。根据需要检查HttpServletRequest,也可以修改HttpServletRequest 头和数据。

在HttpServletResponse到达客户端之前,拦截HttpServletResponse 。根据需要检查HttpServletResponse,也可以修改HttpServletResponse头和数据。


Filter实现拦截功能

Filter接口中有一个doFilter方法,当开发人员编写好Filter,并配置对哪个web资源进行拦截后,Web服务器每次在调用web资源的service方法之前,都会先调用一下filter的doFilter方法,因此,在该方法内编写代码可达到如下目的:

1.调用目标资源之前,让一段代码执行。

2.是否调用目标资源(即是否让用户访问web资源)。

3.web服务器在调用doFilter方法时,会传递一个filterChain对象进来,filterChain对象是filter接口中最重要的一个对象,它也提供了一个doFilter方法,开发人员可以根据需求决定是否调用此方法,调用该方法,则web服务器就会调用web资源的service方法,即web资源就会被访问,否则web资源不会被访问。


这里做了一个登录页面的过滤

先配置web.xml

<filter>
<filter-name>SessionFilter</filter-name>
<filter-class>com.action.login.SessionFilter</filter-class>
<init-param>
   <param-name>logonStrings</param-name><!-- 对登录页面不进行过滤 -->
   <param-value>/project/index.jsp;login.do</param-value>
</init-param>
<init-param>
   <param-name>includeStrings</param-name><!-- 只对指定过滤参数后缀进行过滤 -->
   <param-value>.do;.jsp</param-value>
</init-param>
<init-param>
   <param-name>redirectPath</param-name><!-- 未通过跳转到登录界面 -->
   <param-value>/index.jsp</param-value>
</init-param>
<init-param>
   <param-name>disabletestfilter</param-name><!-- Y:过滤无效 -->
   <param-value>N</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>SessionFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

接着编写

package com.action.login;

       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.HttpServletResponseWrapper;

/**
*    判断用户是否登录,未登录则退出系统
*/
public class SessionFilter implements Filter {

public FilterConfig config;

   public void destroy() {
this.config = null;
   }

public static boolean isContains(String container, String[] regx) {
boolean result = false;

       for (int i = 0; i < regx.length; i++) {
if (container.indexOf(regx[i]) != -1) {
return true;
           }
}
return result;
   }

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest hrequest = (HttpServletRequest)request;
       HttpServletResponseWrapper wrapper = new HttpServletResponseWrapper((HttpServletResponse) response);

       String logonStrings = config.getInitParameter("logonStrings");        // 登录登陆页面
       String includeStrings = config.getInitParameter("includeStrings");    // 过滤资源后缀参数
       String redirectPath = hrequest.getContextPath() + config.getInitParameter("redirectPath");// 没有登陆转向页面
       String disabletestfilter = config.getInitParameter("disabletestfilter");// 过滤器是否有效

       if (disabletestfilter.toUpperCase().equals("Y")) { // 过滤无效
           chain.doFilter(request, response);
           return;
       }
String[] logonList = logonStrings.split(";");
       String[] includeList = includeStrings.split(";");

       if (!this.isContains(hrequest.getRequestURI(), includeList)) {// 只对指定过滤参数后缀进行过滤
           chain.doFilter(request, response);
           return;
       }

if (this.isContains(hrequest.getRequestURI(), logonList)) {// 对登录页面不进行过滤
           chain.doFilter(request, response);
           return;
       }

String user = ( String ) hrequest.getSession().getAttribute("useronly");//判断用户是否登录
       if (user == null) {
wrapper.sendRedirect(redirectPath);
           return;
       }else {
chain.doFilter(request, response);
           return;
       }
}

public void init(FilterConfig filterConfig) throws ServletException {
config = filterConfig;
   }

防止中文乱码过滤器

项目使用spring框架时。当前台JSP页面和Java代码中使用了不同的字符集进行编码的时候就会出现表单提交的数据或者上传/下载中文名称文件出现乱码的问题,那就可以使用这个过滤器。

<filter>
<filter-name>encoding</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
   <param-name>encoding</param-name><!--用来指定一个具体的字符集-->
   <param-value>UTF-8</param-value>
</init-param>
<init-param>
   <param-name>forceEncoding</param-name><!--true:无论request是否指定了字符集,都是用encoding;false:如果request已指定一个字符集,则不使用encoding-->
   <param-value>false</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

明天计划的事情:完成登录页面

遇到的问题:什么样的场景下需要用到多个filter形成filter链

收获:学习了filter



返回列表 返回列表
评论

    分享到