Filter,它的名字是过滤器,可以批量拦截修改servlet的请求和响应。

需要实现接口Filter

配置

<filter> 

    <filter-name>EncodingFilter</filter-name> 

    <filter-class>anni.EncodingFilter</filter-class> 

</filter> 

<filter-mapping> 

    <filter-name>EncodingFilter</filter-name> 

    <url-pattern>/*</url-pattern> 

</filter-mapping>

filter标签部分定义使用的过滤器,

filter-mapping标签告诉服务器把哪些请求交给过滤器处理。这里的

/*表示所有请求,

/表示根路径,

*(星号)代表所有请求,加在一起就变成了根路径下的所有请求。

EncodingFilter.java,来批量设置请求编码。

package

 anni; 

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; 

public

class

 EncodingFilter 

implements

 Filter { 

public

void

 init(FilterConfig config) 

throws

 ServletException {} 

public

void

 destroy() {} 

public

void

 doFilter(ServletRequest request, 

            ServletResponse response, 

            FilterChain chain) 

throws

 IOException, ServletException { 

        request.setCharacterEncoding(

"gb2312"

); 

        chain.doFilter(request, response); 

    } 

}

filter控制用户访问权限

两个点(..)代表当前路径的上一级路径

你可以使用三种方式定义url-pattern

1.直接映射一个请求。

<servlet-mapping> 

    <servlet-name>ContactServlet</servlet-name> 

    <url-pattern>/contact.do</url-pattern> 

</servlet-mapping> 

2,映射一个路径下的所有请求。

<servlet-mapping> 

    <servlet-name>EncodingFilter</servlet-name> 

    <url-pattern>/*</url-pattern> 

</servlet-mapping>

如果这个路径下还有子路径,那么子路径下的请求也会被过滤操作

需要注意的是,这种写法必须以/开头,写成与绝对路径的形式,即便是映射所有请求也要写成/*,不能简化成*

3.映射结尾相同的一类请求

<servlet-mapping> 

    <servlet-name>ControllerServlet</servlet-name> 

    <url-pattern>*.do</url-pattern> 

</servlet-mapping>

这样做的一个好处是语义更清楚,只要看到以.do结尾的请求就知道肯定是交给ControllerServlet处理了,不管这个请求是在根路径还是子路径下,都会准确无误的找到对应的servlet。

缺点就是不同路径之间进行forward,jsp里就不能再使用相对路径了

过滤链

服务器会按照web.xml中过滤器定义的先后循序组装成一条链,然后一次执行其中的doFilter()方法。

而在实际使用时,就要特别注意过滤链的执行顺序问题,像EncodingFilter就一定要放在所有Filter之前,这样才能确保在使用请求中的数据前设置正确的编码

filter详细配置

<filter-mapping> 

    <filter-name>TestFilter</filtername>
<url-pattern>/*</url-pattern>
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
<dispatcher>INCLUDE</dispatcher>
<dispatcher>EXCEPTION</dispatcher> </filter-mapping>

filter过滤指定的servlet

<

filter-mapping

> 

    <filter-name>TestFilter</filter-name> 

    <servlet-name>TestServlet</servlet-name> 

<

/filter-mapping

JSP入门 Filter的更多相关文章

  1. Jsp入门学习笔记

    #Jsp入门 一.JSP基础语法 1.JSP指令: page inlcude taglib 2.JSP注释: a.html注释: <!-- abcdefghijklmn --> b.jsp ...

  2. JSP入门:介绍什么是JSP和Servlet(转)

    转自:http://developer.51cto.com/art/200907/134506.htm JSP入门:什么是jsp? JSP(Java Server Pages)是由Sun Micros ...

  3. JSP入门必读

    JSP基础知识:转自老师上课梳理的笔记,希望对大家有所帮助.有什么不妥当的地方还望大家批评指正. 特别适用于JSP入门的人员使用.1.JSP [1] 简介1.1 HTML    HTML擅长显示一个静 ...

  4. 九、JSP入门(1)

    JSP入门 1 JSP概述 1.1 什么是JSP JSP(Java Server Pages)是JavaWeb服务器端的动态资源.它与html页面的作用是相同的,显示数据和获取数据. 1.2 JSP的 ...

  5. Invalid /admin/*.jsp in filter mapping

    完成错误信息 严重: A child container failed during start java.util.concurrent.ExecutionException: org.apache ...

  6. day11(jsp入门&Cookie&HttpSession&一次性图片校验码)

    day11 JSP入门   1 JSP概述 1.1 什么是JSP JSP(Java Server Pages)是JavaWeb服务器端的动态资源.它与html页面的作用是相同的,显示数据和获取数据. ...

  7. JSP入门之自定义标签

    第二部分简单讲解:主要讲解el表达式,核心标签库.本章主要讲解:自定义标签库:404页面,505页面,错误页面配置方法 全部代码下载:链接 1.JSP自定义标签: 自定义标签是用户定义的JSP语言元素 ...

  8. Jsp入门实战上

    前面讲了servlet入门实践现在开始介绍jsp入门实践,开发环境的搭建请参考我前面的tomcat的文章,jsp入门教程分为上下两部分,第一部分简单讲解:jsp语法的规范,以及三大编译指令,七个动作指 ...

  9. [Java] JSP笔记 - Filter 过滤器

    一.什么是Web过滤器 Servlet API 很久以前就已成为企业应用开发的基石,而 Servlet 过滤器则是对 J2EE 家族的相对较新的补充. Servlet 过滤器是可插入的 Web 组件, ...

随机推荐

  1. javaSE基础之 LinkedList的底层简单实现

    这里贴上LinkedList底层的简单实现 package com.yck.mylinkedlist; public class Node { private Node previous; //上一结 ...

  2. SSH:分页实现

    StudentAction: public class StudentAction extends ActionSupport { // 初始化下拉列表 @Resource private Stude ...

  3. 标准的Java编码规范手册

    编码规范体现出一个开发者的基本素质,良好的编码规范可以提高团队编码的效率,避免很多不必要的问题.今天分享一个标准的Java编码规范给大家,希望对于大家今后的开发工作带来帮助. 编码规范的意义      ...

  4. web安全普及:通俗易懂,如何让网站变得更安全?以实例来讲述网站入侵原理及防护。

    本篇以我自己的网站[http://www.1996v.com]为例来通俗易懂的讲述如何防止网站被入侵,如何让网站更安全. 要想足够安全,首先得知道其中的道理. 本文例子通俗易懂,从"破解网站 ...

  5. 在Hudson Job中启动daemon进程

    场景 在Hudson中新建一个Job用于构建Web工程,在Job的构建脚本的最后会启动Jetty,观察发现Jetty启动之后一小段时间,进程就终止了.   环境 CentOS 6,Hudson 3.0 ...

  6. centos 7 最小安装后 ip配置

    安装玩CentOS7 后要进行 ip的配置 vi /etc/sysconfig/network-scripts/ifcfg-eth0 在里面输入 NAME=eth0 HWADDR=XX:XX:XX:X ...

  7. idea 远程调试

    Idea 远程在线测试 描述:在window下开发,部署到Linux服务器上,往往会遇到在windows下正常运行,在Linux服务器下异常,这是需要本地调试远程代码: 操作步骤: 一.代码已知 保证 ...

  8. C++中关于重载默认构造函数与默认全部参数的构造函数的使用注意

    # include<iostream>using namespace std;class Time{public:                            //公用成员函数  ...

  9. java程序启动参数-D含义详解

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt407 java程序启动参数 -D是用来做什么的呢?去查询了一下官方解释: S ...

  10. sql处理null值

    IFNULL(expr1,expr2) 如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2.IFNULL()返回一个数字或字符串值. select (case when ...