Filter配置详解

web项目目录示意图

<!-- Filter配置 -->
<filter>
<display-name>Filter_one</display-name>
<filter-name>Filter_one</filter-name>
<filter-class>com.my.filter.Filter_one</filter-class>
</filter>
<filter-mapping>
<filter-name>Filter_one</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter>
<display-name>Filter_two</display-name>
<filter-name>Filter_two</filter-name>
<filter-class>com.my.filter.Filter_two</filter-class>
</filter>
<filter-mapping>
<filter-name>Filter_two</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter>
<display-name>Filter_three</display-name>
<filter-name>Filter_three</filter-name>
<filter-class>com.my.filter.Filter_three</filter-class>
</filter>
<filter-mapping>
<filter-name>Filter_three</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping> <!-- servlet配置 -->
<servlet>
<description></description>
<display-name>Servlet_one</display-name>
<servlet-name>Servlet_one</servlet-name>
<servlet-class>com.my.servlet.Servlet_one</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Servlet_one</servlet-name>
<url-pattern>/Servlet_one</url-pattern>
</servlet-mapping>
<servlet>
<description></description>
<display-name>Servlet_two</display-name>
<servlet-name>Servlet_two</servlet-name>
<servlet-class>com.my.servlet.Servlet_two</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Servlet_two</servlet-name>
<url-pattern>/Servlet_two</url-pattern>
</servlet-mapping>
<servlet>
<description></description>
<display-name>Servlet_three</display-name>
<servlet-name>Servlet_three</servlet-name>
<servlet-class>com.my.servlet.Servlet_three</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Servlet_three</servlet-name>
<url-pattern>/Servlet_three</url-pattern>
</servlet-mapping>
//Filter_one重写的doFilter语句
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.err.println("Filter_one前====>");
chain.doFilter(request, response);
System.err.println("Filter_one后====>");
}
//Filter_two重写的doFilter语句
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.err.println("Filter_two前====>");
chain.doFilter(request, response);
System.err.println("Filter_two后====>");
}
//Filter_three重写的doFilter语句
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
System.err.println("Filter_three前====>");
chain.doFilter(request, response);
System.err.println("Filter_three后====>");
}
//Servlet_one重写doGet方法
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.err.println("Servlet_one===>");
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
//Servlet_two重写doGet方法
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.err.println("Servlet_two===>");
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
//Servlet_three重写doGet方法
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.err.println("Servlet_three===>");
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}

已知:过滤器Filter_one、Filter_two、Filter_three都会对Servlet_one进行拦截,那么当我们在浏览器地址输入Servlet_one,客户端会打印什么呢?

输入Servlet_one地址

客户端打印结果

传递资源会经过Filter_one、Filter_two、Filter_three三个过滤器,到达Servlet_one,访问结束后响应又会经过Filter_one、Filter_two、Filter_three三个过滤器,所以才有上图的结果

修改Servlet_one代码

//Servlet_one重写doGet方法
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
  System.err.println("Servlet_one===>");
  request.getRequestDispatcher("/Servlet_two").forward(request, response);

重定向到Servlet_two结果又会是怎样呢?结果是如下表左边还是右边呢?

Filter_one前====>

Filter_two前====>

Filter_three前====>

Servlet_one===>

Servlet_two===>

Filter_three后====>

Filter_two后====>

Filter_one后====>

Filter_one前====>

Filter_two前====>

Filter_three前====>

Servlet_one===>

Filter_one前====>

Filter_two前====>

Filter_three前====>

Servlet_two===>

Filter_three后====>

Filter_two后====>

Filter_one后====>

Filter_three后====>

Filter_two后====>

Filter_one后====>

结果如上表(结果左)所示

这是为什么呢?过滤器不是对项目内所有文件都要进行过滤吗?为什么这里没有对Servlet_two进行过滤?原因就在这里<dispatcher>标签,内含四个参数:FORWARD、ERROR、INCLUDE、REQUEST;REQUEST为默认标签,并且一个<filter-mapping>内可以包含多个<dispatcher>标签;

修改Filter_one代码

  <filter-mapping>
<filter-name>Filter_one</filter-name>
<url-pattern>/*</url-pattern>
<dispatcher>FORWARD</dispatcher>
<dispatcher>REQUEST</dispatcher>
</filter-mapping>

修改后结果如图所示

结果示意图

这样就可以在Servlet_one跳转到Servlet_two的时候,对Servlet_two也进行过滤。

ERROR参数又有什么作用呢?已知我们在程序调试的时候难免出现异常,或者url路径填写错误,那么网页就会提示这些错误

Error Status 500

Error Status 404

这样的错误提示信息较为相信,明眼人一眼就能看见错误信息,这样你的后台信息就会暴露出来,这样是非常不好。那么怎么替代这些错误信息呢?就要用到<dispatcher>标签中的ERROR参数。

修改Filter_one代码

<!--在标签<filter-mapping>中添加子标签<dispatcher>并且参数为ERROR-->
<dispatcher>ERROR</dispatcher>
<!--在标签<web-app>中添加子标签<error-page>-->
<error-page>
<!--状态码-->
<error-code>404</error-code>
<!--连接路径-->
<location>/Test/WebContent/jsp/error_404_page.jsp</location>
</error-page>
<error-page>
<error-code>500</error-code>
<location>/Test/WebContent/jsp/error_500_page.jsp</location>
</error-page>

当程序再出现异常的时候,就会跳转到我们自己设计的错误提示页面,不会将源代码错误信息显示在页面上。既美化又更加安全、健壮!

Error Status 500

Error Status 404

Filter配置详解

web项目目录示意图

<!-- Filter配置 -->

<filter>

<display-name>Filter_one</display-name>

<filter-name>Filter_one</filter-name>

<filter-class>com.my.filter.Filter_one</filter-class>

</filter>

<filter-mapping>

<filter-name>Filter_one</filter-name>

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

</filter-mapping>

<filter>

<display-name>Filter_two</display-name>

<filter-name>Filter_two</filter-name>

<filter-class>com.my.filter.Filter_two</filter-class>

</filter>

<filter-mapping>

<filter-name>Filter_two</filter-name>

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

</filter-mapping>

<filter>

<display-name>Filter_three</display-name>

<filter-name>Filter_three</filter-name>

<filter-class>com.my.filter.Filter_three</filter-class>

</filter>

<filter-mapping>

<filter-name>Filter_three</filter-name>

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

</filter-mapping>

<!-- servlet配置 -->

<servlet>

<description></description>

<display-name>Servlet_one</display-name>

<servlet-name>Servlet_one</servlet-name>

<servlet-class>com.my.servlet.Servlet_one</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>Servlet_one</servlet-name>

<url-pattern>/Servlet_one</url-pattern>

</servlet-mapping>

<servlet>

<description></description>

<display-name>Servlet_two</display-name>

<servlet-name>Servlet_two</servlet-name>

<servlet-class>com.my.servlet.Servlet_two</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>Servlet_two</servlet-name>

<url-pattern>/Servlet_two</url-pattern>

</servlet-mapping>

<servlet>

<description></description>

<display-name>Servlet_three</display-name>

<servlet-name>Servlet_three</servlet-name>

<servlet-class>com.my.servlet.Servlet_three</servlet-class>

</servlet>

<servlet-mapping>

<servlet-name>Servlet_three</servlet-name>

<url-pattern>/Servlet_three</url-pattern>

</servlet-mapping>

//Filter_one重写的doFilter语句

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {

System.err.println("Filter_one前====>");

chain.doFilter(request, response);

System.err.println("Filter_one后====>");

}

//Filter_two重写的doFilter语句

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {

System.err.println("Filter_two前====>");

chain.doFilter(request, response);

System.err.println("Filter_two后====>");

}

//Filter_three重写的doFilter语句

public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {

System.err.println("Filter_three前====>");

chain.doFilter(request, response);

System.err.println("Filter_three后====>");

}

//Servlet_one重写doGet方法

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

System.err.println("Servlet_one===>");

}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

doGet(request, response);

}

//Servlet_two重写doGet方法

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

System.err.println("Servlet_two===>");

}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

doGet(request, response);

}

//Servlet_three重写doGet方法

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

System.err.println("Servlet_three===>");

}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

doGet(request, response);

}

已知:过滤器Filter_one、Filter_two、Filter_three都会对Servlet_one进行拦截,那么当我们在浏览器地址输入Servlet_one,客户端会打印什么呢?

输入Servlet_one地址

客户端打印结果

过滤示意图

传递资源会经过Filter_one、Filter_two、Filter_three三个过滤器,到达Servlet_one,访问结束后响应又会经过Filter_one、Filter_two、Filter_three三个过滤器,所以才有上图的结果。

修改Servlet_one代码

//Servlet_one重写doGet方法

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

System.err.println("Servlet_one===>");request.getRequestDispatcher("/Servlet_two").forward(request, response);

}

重定向到Servlet_two结果又会是怎样呢?

结果是如左边还是右边呢?

Filter_one前====>

Filter_two前====>

Filter_three前====>

Servlet_one===>

Servlet_two===>

Filter_three后====>

Filter_two后====>

Filter_one后====>

Filter_one前====>

Filter_two前====>

Filter_three前====>

Servlet_one===>

Filter_one前====>

Filter_two前====>

Filter_three前====>

Servlet_two===>

Filter_three后====>

Filter_two后====>

Filter_one后====>

Filter_three后====>

Filter_two后====>

Filter_one后====>

结果如上表(结果左)所示

这是为什么呢?过滤器不是对项目内所有文件都要进行过滤吗?为什么这里没有对Servlet_two进行过滤?原因就在这里<dispatcher>标签,内含四个参数:FORWARD、ERROR、INCLUDE、REQUEST;REQUEST为默认标签,并且一个<filter-mapping>内可以包含多个<dispatcher>标签;

修改Filter_one代码

<filter-mapping>

<filter-name>Filter_one</filter-name>

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

<dispatcher>FORWARD</dispatcher>

<dispatcher>REQUEST</dispatcher>

</filter-mapping>

修改后结果如图所示

结果示意图

这样就可以在Servlet_one跳转到Servlet_two的时候,对Servlet_two也进行过滤。

ERROR参数又有什么作用呢?已知我们在程序调试的时候难免出现异常,或者url路径填写错误,那么网页就会提示这些错误

Error Status 500

Error Status 404

这样的错误提示信息较为相信,明眼人一眼就能看见错误信息,这样你的后台信息就会暴露出来,这样是非常不好。那么怎么替代这些错误信息呢?就要用到<dispatcher>标签中的ERROR参数。

修改Filter_one代码

在标签<filter-mapping>中添加子标签<dispatcher>并且参数为ERROR

<dispatcher>ERROR</dispatcher>

在标签<web-app>中添加子标签<error-page>

<error-page>

<!--状态码-->

<error-code>404</error-code>

<!--连接路径-->

<location>/Test/WebContent/jsp/error_404_page.jsp</location>

</error-page>

<error-page>

<error-code>500</error-code>

<location>/Test/WebContent/jsp/error_500_page.jsp</location>

</error-page>

当程序再出现异常的时候,就会跳转到我们自己设计的错误提示页面,不会将源代码错误信息显示在页面上。既美化又更加安全、健壮!

Error Status 500

Error Status 404

JavaWeb总结(十)的更多相关文章

  1. javaweb(二十二)——基于Servlet+JSP+JavaBean开发模式的用户登录注册

    一.Servlet+JSP+JavaBean开发模式(MVC)介绍 Servlet+JSP+JavaBean模式(MVC)适合开发复杂的web应用,在这种模式下,servlet负责处理用户请求,jsp ...

  2. JavaWeb总结(十)—文件上传和下载

    一.文件的上传 1.文件的基本上传 对于文件上传,浏览器在上传的过程中是将文件以流的形式提交到服务器端的,如果直接使用Servlet获取上传文件的输入流然后再解析里面的请求参数是比较麻烦,所以一般选择 ...

  3. JavaWeb 后端 <十四> 文件上传下载

    1.文件上传与下载 案例: 注册表单/保存商品等相关模块! --à 注册选择头像 / 商品图片 (数据库:存储图片路径 / 图片保存到服务器中指定的目录) 1.1 文件上传 文件上传,要点: 前台: ...

  4. JavaWeb 后端 <十二> 之 过滤器 filter 乱码、不缓存、脏话、标记、自动登录、全站压缩过滤器

    一.过滤器是什么?有什么? 1.过滤器属于Servlet规范,从2.3版本就开始有了. 2.过滤器就是对访问的内容进行筛选(拦截).利用过滤器对请求和响应进行过滤

  5. JavaWeb 后端 <十> 之 数据池 C3P0 DPCB JNDI

    一.数据库连接池原理:(理解) //模拟数据库连接池的原理 public class ConnectionPoolDemo { private static List<Connection> ...

  6. JavaWeb学习 (十九)————JavaBean

    一.什么是JavaBean JavaBean是一个遵循特定写法的Java类,它通常具有如下特点: 这个Java类必须具有一个无参的构造函数 属性必须私有化. 私有化的属性必须通过public类型的方法 ...

  7. JavaWeb学习 (十八)————JSP标签

    一.JSP标签介绍 JSP标签也称之为Jsp Action(JSP动作)元素,它用于在Jsp页面中提供业务逻辑功能,避免在JSP页面中直接编写java代码,造成jsp页面难以维护. 二.JSP常用标签 ...

  8. JavaWeb学习 (十六)————JSP中的九个内置对象

    一.JSP运行原理 每个JSP 页面在第一次被访问时,WEB容器都会把请求交给JSP引擎(即一个Java程序)去处理.JSP引擎先将JSP翻译成一个_jspServlet(实质上也是一个servlet ...

  9. JavaWeb学习 (十五)————JSP指令

    一.JSP指令简介 JSP指令(directive)是为JSP引擎而设计的,它们并不直接产生任何可见输出,而只是告诉引擎如何处理JSP页面中的其余部分. 在JSP 2.0规范中共定义了三个指令: pa ...

  10. JavaWeb学习 (十四)————JSP基础语法

    一.JSP模版元素 JSP页面中的HTML内容称之为JSP模版元素.  JSP模版元素定义了网页的基本骨架,即定义了页面的结构和外观. 二.JSP表达式 JSP脚本表达式(expression)用于将 ...

随机推荐

  1. LeetCode题解之Single Number

    1.题目描述 2.分析 3.代码 int singleNumber(vector<int>& nums) { map<int,int> m; for( vector&l ...

  2. 使用 Azure CLI 创建和管理 Linux VM

    Azure 虚拟机提供完全可配置的灵活计算环境. 本教程介绍 Azure 虚拟机的基本部署项目,例如选择 VM 大小.选择 VM 映像和部署 VM. 你将学习如何执行以下操作: 创建并连接到 VM 选 ...

  3. 如何修改ionic中android程序的包名

    默认ionic新建工程的时候指定的Android版本包名是:com.ionicframework.starter:这样固定死包名的话会导致一个问题,多个ionic工程无法正常安装到手机当中,后面安装的 ...

  4. Oracle EBS 锁

    这里仅提供查询锁和解锁.有时,锁是正常的,所以杀掉正锁着的进程有一定的风险性. 具体步骤如下: -- 1.0 查看 holder的进程 , 'Holder: ', 'Waiter: ') || sid ...

  5. Oracle EBS PO采购订单更新

    DECLARE l_result NUMBER; l_progress NUMBER; l_errors PO_API_ERRORS_REC_TYPE; l_chg PO_CHANGES_REC_TY ...

  6. Mysqlbinlog工具及导出数据并转换编码导入

    2014 - binlog是通过记录二进制文件方式来备份数据,然后在从二进制文件将数据恢复到某一时段或某一操作点. 1.使用mysqlbinlog工具来恢复 Mysqlbinlog日志如何开启? 在m ...

  7. django配置连接多个数据库,自定义表名称

    在项目tt下新建两个app,分别为app01.app02.配置app01使用default节点数据库:app02使用hvdb节点数据库(也可以配置app01下的model既使用default,也可以使 ...

  8. September 07th 2017 Week 36th Thursday

    With the most true of yourself, can you meet the most suitable one. 用最真实的自己,才能遇见最合适的那个人. You are alw ...

  9. GNSS基础(持续更新)

    1.整周模糊度成功率 可参考文献:GNSS整周模糊度概率特性 2.正太分布 见百度百科 https://baike.baidu.com/item/%E6%AD%A3%E6%80%81%E5%88%86 ...

  10. 使用MS的ScriptDom来拆解TSQL脚本

    此处提供9.1.40413.0版本的DLL一共4个:Microsoft.Data.Schema.dll.Microsoft.Data.Schema.ScriptDom.dll.Microsoft.Da ...