博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaWeb学习-Filter-2-Filter声明周期和FilterConfig
阅读量:4302 次
发布时间:2019-05-27

本文共 1980 字,大约阅读时间需要 6 分钟。

我们前面学习过Servlet的生命周期,同样FilterConfig的生命周期也差不多。这篇来学习Filter的生命周期和FilterConfig这两个知识点。

 

1. Filter的生命周期

 

我们先来复习下Servler的生命周期:实例化->初始化-> 服务->销毁

Servlet是这样,只有在第一次访问该servlet的时候,才会进行实例化,然后初始化,然后执行service方法中的代码,最后app卸载或者tomcat服务关机,才会销毁。

 

Filter的生命周期有点类似:

  • 当服务器启动,会创建Filter对象,并调用init方法,只调用一次。
  • 当访问资源时,路径与Filter的拦截路径匹配,会执行Filter中的doFilter方法,这个方法时真正拦截操作的方法。
  • 当服务器关闭,会调用Filter的destory方法进行销毁操作。

 

这里我们来代码练习一下,利用前面这个MyFilter.java来修改下代码。

package com.anthony.filter;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 MyFilter implements Filter {	public MyFilter() {		System.out.println("MyFilter对象实例化了");	}		@Override	public void destroy() {		System.out.println("MyFilter对象销毁了");	}	@Override	public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)			throws IOException, ServletException {		System.out.println("doFilter执行了拦截");		// 放行		chain.doFilter(request, response);	}	@Override	public void init(FilterConfig filterConfig) throws ServletException {		System.out.println("MyFilter对象初始化了");	}}

重新部署下Tomcat,看看控制台这几句话是否打印出来。

1.先看看启动Tomcat的时候实例化和初始化是否执行

2.执行拦截操作

我们访问一下/servletDemo1,应该会执行拦截,打印消息

这里的doFilter方法,访问一次servlet就好执行一次doFilter中代码。

3.关闭tomcat服务器,执行销毁方法

在Servers Tab,右键Tomcat服务器,点击stop,相当于关闭tomcat服务器。

 

 

2.FilterConfig

在Filter生命周期方法中init()方法有一个参数就是FilterConfig,我们来学习下这个对象的功能的基本使用。

FilterConfig它时Filter的配置对象,它可以完成下列功能

  • 获取Filter名称
  • 获取Filter初始化参数
  • 获取ServletContext对象

下面我们来代码演示下第二个获取初始化参数的功能。

这里新建一个FilterConfigTest.java,也需要实现Filter接口。

先在web.xml中配置一下Filter和初始化参数。

FilterConfigTest
com.anthony.filter.FilterConfigTest
encoding
UTF-8
FilterConfigTest
/*

在原有基础上加上上面配置,保存web.xml文件,然后在FilterConfigTest.java写入如下代码。

在浏览器刷新之后访问,

控制台是可以打印UTF-8这个值。

 

转载地址:http://inows.baihongyu.com/

你可能感兴趣的文章
大数据学习之路------借助HDP SANDBOX开始学习
查看>>
Hadoop基础学习:基于Hortonworks HDP
查看>>
为什么linux安装程序 都要放到/usr/local目录下
查看>>
Hive安装前扫盲之Derby和Metastore
查看>>
永久修改PATH环境变量的几种办法
查看>>
大数据学习之HDP SANDBOX开始学习
查看>>
Hive Beeline使用
查看>>
Centos6安装图形界面(hdp不需要,hdp直接从github上下载数据即可)
查看>>
CentOS7 中把yum源更换成163源
查看>>
关于yum Error: Cannot retrieve repository metadata (repomd.xml) for repository:xxxxxx.
查看>>
linux下载github中的文件
查看>>
HDP Sandbox里面git clone不了数据(HTTP request failed)【目前还没解决,所以hive的练习先暂时搁置了】
查看>>
动态分区最佳实践(一定要注意实践场景)
查看>>
HIVE—索引、分区和分桶的区别
查看>>
Hive进阶总结(听课总结)
查看>>
大数据领域两大最主流集群管理工具Ambari和Cloudera Manger
查看>>
Sqoop往Hive导入数据实战
查看>>
Mysql到HBase的迁移
查看>>
Sqoop import进阶
查看>>
Hive语句是如何转化成MapReduce任务的
查看>>