概述:

过滤器是Servlet2.3以上新添加的一个功能,其技术也是很强大的。通过Filter技术能够对WEBserver的文件进行拦截,从而实现一些特殊的功能。

在JSP开发应用中也是必备的技能之中的一个。

Filter能够改变一个request(请求)和改动一个response(响应)。Filter不是一个Servlet,它不能产生一个response,它能够在一个requsst到达Servlet之前预处理request,也能够在离开Servlet时处理response。

原理:

当Web容器接受到一个对资源的请求时。它将推断是否有过滤器与这个资源关联。假设有的话容器把请求交给过滤器处理,在过滤器中,能够改变请求的内容,或者又一次设置请求的信息,然后再将请求发送给目标资源,当目标资源对请求做出响应后,容器相同将响应先转发给过滤器,过滤器能够对响应的内容进行转换,然后再将响应发送到client

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2pyMTUyMzM2NjExNDM=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

在一个Web应用中,是能够部署多个过滤器的。组成一个过滤器链。过滤器链中的每一个过滤器负责特定的操作和任务,client的请求在这些过滤器之间传递,直到目标资源。WEBserver依据Filter在web.xml文件里的注冊顺序决定先调用哪一个Filter,当地一个Filter的doFilter方法被调用时,WEBserver会创建一个Filter链的FilterChain对象传递给该方法。

说明:FIlter不是一个标准的Servlet,不能处理用户请求,也不能对client生成响应。

主要用于对HttpServletRequest进行预处理,也能够对HttpServletResponse进行后处理。

HttpServletRequest和HttpServletResponse工作流程

首先,在HttpServletRequest到达Servlet之前,拦截客户的HttpServletRequest,然后依据须要检查HttpServletRequest,也能够改动HttpServletRequest头和数据,当HttpServletResponse到达client之前。拦截HttpServletResponse,依据须要检查HttpServletResponse。也能够改动HttpServletResponse的头和数据。

比方说当对用户发送的数据进行过滤,替换时就使用到这一点。

Filter使用基础

1.一个Filter必须实现javax.servlet,Filter接口并定义下面三个方法:

<!--Filter实例化后进行初始化的回调方法-->

public void init(FilterConfig config)

<!--处理过滤器的方法-->

public void doFilter(ServletRequest  request,ServletResponse response,FilterChain)

<!--在释放时回调的方法-->

public void destory()

2.FilterConfig接口

在配置filter时,能够使用<init-parm>为filter配置一些初始化參数,当web容器实例化Filter对象时。调用init方法时,会把封装了filter初始化參数的filterConfig对象传递进来,因此在编写filter时,通过filterConfig对象的方法,就能够通过getFilterName()获得filter的名字,使用String
getInitParamerter(String name)获得在部署描写叙述中指定名称的初始化參数的值等

3.在web.xml文件里使用<filter>和<filter-mapping>元素对编写的filter类进行注冊。并设置它所能拦截的资源。

以下通过介绍登陆的时加上过滤器这个样例介绍web.xml怎么配置

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>

FilterServlet

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;
}
}

这样FIlter就能够帮你过滤了。

        总结:上篇文章简单对拦截器有一个了解,今天 又学习了FIlter这个过滤器。除了用法不一样以外它们还有非常多不同的地方,如:filter基于回调函数。我们须要实现的filter接口中doFilter方法就是回调函数。而interceptor则基于java本身的反射机制,这是两者最本质的差别,filter是依赖于servlet容器的。即仅仅能在servlet容器中运行,非常显然没有servlet容器就无法来回调doFilter方法。而interceptor与servlet容器无关。还有就是拦截器由spring管理,仅仅对action起作用,不能拦截jsp页面、图片等其它资源。

拦截器截获用户对action的訪问,如须要跳转,仅仅需如action一样返回一个result,spring依据result的配置运行跳转。如无需跳转。可调用invocation.invoke();方法来运行用户请求的action。拦截器在action之前開始,在action完毕后结束。肯定还有非常多不同的地方,学习到这里仅仅体会到了这些。欢迎大家一起分享。

SSH2——filter过滤器的更多相关文章

  1. filter 过滤器(监听)

    Filter 过滤器 1.简介 Filter也称之为过滤器,它是Servlet技术中最实用的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, ...

  2. Java防止SQL注入2(通过filter过滤器功能进行拦截)

    首先说明一点,这个过滤器拦截其实是不靠谱的,比如说我的一篇文章是介绍sql注入的,或者评论的内容是有关sql的,那会过滤掉:且如果每个页面都经过这个过滤器,那么效率也是非常低的. 如果是要SQL注入拦 ...

  3. Filter(过滤器)学习

    一.Filter简介 Filter也称之为过滤器,它是Servlet技术中最激动人心的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态 ...

  4. javaweb学习总结(四十二)——Filter(过滤器)学习

    一.Filter简介 Filter也称之为过滤器,它是Servlet技术中最激动人心的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态 ...

  5. Filter过滤器简单应用( 接口访问控制 )

    一.描述 在提供安卓.IOS客户端接口时,可以在登陆接口分配Session给客户端,用于判断其他接口是否是合法访问,以避免将所有的接口都暴露在web中可以由路径直接访问.但是最近的一个项目中的移动接口 ...

  6. 如何配置Filter过滤器处理JSP中文乱码

    参考Tomcat服务器目录webapps的examples示例 简单配置步骤:1.在项目web.xml文件添加过滤器标记<filter>和<filter-mapping>:2. ...

  7. Filter(过滤器)常见应用

    孤傲苍狼 只为成功找方法,不为失败找借口! javaweb学习总结(四十六)——Filter(过滤器)常见应用 一.统一全站字符编码 通过配置参数charset指明使用何种字符编码,以处理Html F ...

  8. Filter过滤器(1)

    Filter也称之为过滤器,它是Servlet技术中比较激动人心的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 ht ...

  9. Servlet的学习之Filter过滤器技术(1)

    本篇将讲诉Servlet中一项非常重要的技术,Filter过滤器技术.通过过滤器,可以对来自客户端的请求进行拦截,进行预处理或者对最终响应给客户端的数据进行处理后再输出. 要想使用Filter过滤器, ...

随机推荐

  1. Java实现邮箱发送验证码

    第一步,导入JAR包,JAR包下载地址[http://pan.baidu.com/s/1kVRvGyF] 正式代码: 首先书写一个工具类: MailUtil import javax.mail.*; ...

  2. 【Java入门提高篇】Day2 接口

    上一篇讲完了抽象类,这一篇主要讲解比抽象类更加抽象的内容--接口. 什么是接口呢?先来看个栗子: /** * @author Frank * @create 2017/11/22 * @descrip ...

  3. 冒泡排序-Python与PHP实现版

    Python实现 import random a=[random.randint(1,999) for x in range(0,33)] # 冒泡排序,python中数组是按引用传递的,会直接在原数 ...

  4. 常见的Mysql数据库优化总结

    索引 1.主键索引 作用:唯一约束和提高查询速度 #建表时创建主键索引 create table `table_name`( `id` int unsigned not null auto_incre ...

  5. open_basedir restriction in effect.文件访问没有权限异常

    本次搭建公司web开发环境遇到了不少坑首先认为可能是设置的目录写入权限问题,后面解决了发现不是 问题在于nginx配置文件进行了网站目录的保护 配置文件/usr/local/nginx/conf/fa ...

  6. JVM菜鸟进阶高手之路十四:分析篇

    转载请注明原创出处,谢谢! 题目回顾 JVM菜鸟进阶高手之路十三,问题现象就是相同的代码,jvm参数不一样,表现的现象不一样. private static final int _1MB = 1024 ...

  7. Entity Framework Core 使用HiLo生成主键

    #cnblogs_post_body.cnblogs-markdown p img { max-width: 95%; } HiLo是在NHiernate中生成主键的一种方式,不过现在我们可以在Ent ...

  8. 常用的redis命令

      常用的redis命令 http://www.runoob.com/redis/redis-tutorial.html 菜鸟教程   Cmd连接有密码的redis:$ redis-cli -h ho ...

  9. ExpandableListView使用

    相关博客 ExpandableListView使用 博客内容记录 场景 有时候,使用ListView并不能满足应用程序所需要的功能.有些应用程序需要多组ListView,这时候我们就要使用一种新的控件 ...

  10. 02-线性结构3 Reversing Linked List

    题目 Sample Input: 00100 6 4 00000 4 99999 00100 1 12309 68237 6 -1 33218 3 00000 99999 5 68237 12309 ...