Web三大组件之Filter,Listener和Servlet详解

 更新时间:2022年03月09日 16:28:57   作者:Love_cangXin  
这篇文章主要为大家详细介绍了Web三大组件之Filter,Listener和Servlet,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助

Filter:过滤器

 1. 概念:
* 生活中的过滤器:净水器,空气净化器,土匪、
* web中的过滤器:当访问服务器的资源时,过滤器可以将请求拦截下来,完成一些特殊的功能。
* 过滤器的作用:
	* 一般用于完成通用的操作。如:登录验证、统一编码处理、敏感字符过滤...
2. 快速入门:
1. 步骤:
	1. 定义一个类,实现接口Filter
	2. 复写方法
	3. 配置拦截路径
		1. web.xml
		2. 注解
2. 代码:
	@WebFilter("/*")//访问所有资源之前,都会执行该过滤器
	public class FilterDemo1 implements Filter {
	    @Override
	    public void init(FilterConfig filterConfig) throws ServletException {
	    }
	    @Override
	    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
	        System.out.println("filterDemo1被执行了....");
	         //放行
	        filterChain.doFilter(servletRequest,servletResponse);
	    }
	    @Override
	    public void destroy() {
	    }
	}
 3. 过滤器细节:
  1. web.xml配置	
	<filter>
        <filter-name>demo1</filter-name>
        <filter-class>cn.itcast.web.filter.FilterDemo1</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>demo1</filter-name>
		<!-- 拦截路径 -->
        <url-pattern>/*</url-pattern>
    </filter-mapping>
2. 过滤器执行流程
	1. 执行过滤器
	2. 执行放行后的资源
	3. 回来执行过滤器放行代码下边的代码
3. 过滤器生命周期方法
	1. init:在服务器启动后,会创建Filter对象,然后调用init方法。只执行一次。用于加载资源
	2. doFilter:每一次请求被拦截资源时,会执行。执行多次
	3. destroy:在服务器关闭后,Filter对象被销毁。如果服务器是正常关闭,则会执行destroy方法。只执行一次。用于释放资源
4. 过滤器配置详解
	* 拦截路径配置:
		1. 具体资源路径: /index.jsp   只有访问index.jsp资源时,过滤器才会被执行
		2. 拦截目录: /user/*	访问/user下的所有资源时,过滤器都会被执行
		3. 后缀名拦截: *.jsp		访问所有后缀名为jsp资源时,过滤器都会被执行
		4. 拦截所有资源:/*		访问所有资源时,过滤器都会被执行
	* 拦截方式配置:资源被访问的方式
		* 注解配置:
			* 设置dispatcherTypes属性
				1. REQUEST:默认值。浏览器直接请求资源
				2. FORWARD:转发访问资源
				3. INCLUDE:包含访问资源
				4. ERROR:错误跳转资源
				5. ASYNC:异步访问资源
		* web.xml配置
			* 设置<dispatcher></dispatcher>标签即可
5. 过滤器链(配置多个过滤器)
	* 执行顺序:如果有两个过滤器:过滤器1和过滤器2
		1. 过滤器1
		2. 过滤器2
		3. 资源执行
		4. 过滤器2
		5. 过滤器1 
	* 过滤器先后顺序问题:
		1. 注解配置:按照类名的字符串比较规则比较,值小的先执行
			* 如: AFilter 和 BFilter,AFilter就先执行了。
		2. web.xml配置: <filter-mapping>谁定义在上边,谁先执行

Listener:监听器

* 概念:web的三大组件之一。
* 事件监听机制
	* 事件	:一件事情
	* 事件源 :事件发生的地方
	* 监听器 :一个对象
	* 注册监听:将事件、事件源、监听器绑定在一起。 当事件源上发生某个事件后,执行监听器代码

* ServletContextListener:监听ServletContext对象的创建和销毁
* 方法:
	* void contextDestroyed(ServletContextEvent sce) :ServletContext对象被销毁之前会调用该方法
	* void contextInitialized(ServletContextEvent sce) :ServletContext对象创建后会调用该方法
* 步骤:
	1. 定义一个类,实现ServletContextListener接口
	2. 复写方法
	3. 配置
		1. web.xml
				<listener>
				 <listener-class>cn.itcast.web.listener.ContextLoaderListener</listener-class>
			 </listener>
* 指定初始化参数<context-param>
		2. 注解:
			* @WebListener

servlet

* 概念:运行在服务器端的小程序
* Servlet就是一个接口,定义了Java类被浏览器访问到(tomcat识别)的规则。
* 将来我们自定义一个类,实现Servlet接口,复写方法。
* * 快速入门:
1. 创建JavaEE项目
2. 定义一个类,实现Servlet接口
	* public class ServletDemo1 implements Servlet
3. 实现接口中的抽象方法
4. 配置Servlet
	 在web.xml中配置:
    <!--配置Servlet -->
    <servlet>
        <servlet-name>demo1</servlet-name>
        <servlet-class>cn.itcast.web.servlet.ServletDemo1</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>demo1</servlet-name>
        <url-pattern>/demo1</url-pattern>
    </servlet-mapping>
 * 执行原理:
1. 当服务器接受到客户端浏览器的请求后,会解析请求URL路径,获取访问的Servlet的资源路径
2. 查找web.xml文件,是否有对应的<url-pattern>标签体内容。
3. 如果有,则在找到对应的<servlet-class>全类名
4. tomcat会将字节码文件加载进内存,并且创建其对象
5. 调用其方法
* Servlet中的生命周期方法:
1. 被创建:执行init方法,只执行一次
	* Servlet什么时候被创建?
		* 默认情况下,第一次被访问时,Servlet被创建
		* 可以配置执行Servlet的创建时机。
			* 在<servlet>标签下配置
				1. 第一次被访问时,创建
            		* <load-on-startup>的值为负数
	            2. 在服务器启动时,创建
	                * <load-on-startup>的值为0或正整数
 * Servlet的init方法,只执行一次,说明一个Servlet在内存中只存在一个对象,Servlet是单例的
		* 多个用户同时访问时,可能存在线程安全问题。
		* 解决:尽量不要在Servlet中定义成员变量。即使定义了成员变量,也不要对修改值
2. 提供服务:执行service方法,执行多次
	* 每次访问Servlet时,Service方法都会被调用一次。
3. 被销毁:执行destroy方法,只执行一次
	* Servlet被销毁时执行。服务器关闭时,Servlet被销毁
	* 只有服务器正常关闭时,才会执行destroy方法。
	* destroy方法在Servlet被销毁之前执行,一般用于释放资源
* Servlet3.0:
* 好处:
	* 支持注解配置。可以不需要web.xml了。
* 步骤:
	1. 创建JavaEE项目,选择Servlet的版本3.0以上,可以不创建web.xml
	2. 定义一个类,实现Servlet接口
	3. 复写方法
	4. 在类上使用@WebServlet注解,进行配置
		* @WebServlet("资源路径")

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容! 

相关文章

  • 一文带你深入理解Java AbstractQueuedSynchronizer

    一文带你深入理解Java AbstractQueuedSynchronizer

    在并发编程中,锁是一种保证线程安全的方式,这篇文章主要为大家介绍了AbstractQueuedSynchronizer(AQS)的数据结构及实现原理,感兴趣的小伙伴可以了解一下
    2023-07-07
  • Java Validation Api如何实现自定义注解

    Java Validation Api如何实现自定义注解

    这篇文章主要介绍了Java Validation Api如何实现自定义注解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • 初识Spring Boot框架和快速入门

    初识Spring Boot框架和快速入门

    这篇文章主要介绍了初识Spring Boot框架学习,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • java实现表格数据的存储

    java实现表格数据的存储

    这篇文章主要为大家详细介绍了java实现表格数据的存储,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • mybatis一级缓存和二级缓存的区别及说明

    mybatis一级缓存和二级缓存的区别及说明

    这篇文章主要介绍了mybatis一级缓存和二级缓存的区别及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • Spring Cloud Alibaba配置多环境管理详解与实战代码

    Spring Cloud Alibaba配置多环境管理详解与实战代码

    本文通过实际案例详细介绍了springboot配置多环境管理的使用,以及基于nacos的配置多环境管理的实践,在实际开发中,配置多环境管理是一个很难避开的问题,同时也是微服务治理中一个很重要的内容,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • package打包一个springcloud项目的某个微服务报错问题

    package打包一个springcloud项目的某个微服务报错问题

    这篇文章主要介绍了package打包一个springcloud项目的某个微服务报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-07-07
  • Mybatis实体类和表映射问题(推荐)

    Mybatis实体类和表映射问题(推荐)

    在项目开发中我们经常会遇到表中的字段名和表对应实体类的属性名称不一定都是完全相同的。下面小编给大家介绍下这种情况下如何解决字段名与实体类属性名不相同的冲突问题。下面小编给大家带来了Mybatis实体类和表映射的解决方法,小伙伴们一起学习吧
    2016-09-09
  • jdbc+jsp实现简单员工管理系统

    jdbc+jsp实现简单员工管理系统

    这篇文章主要为大家详细介绍了jdbc+jsp实现简单员工管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-02-02
  • volatile与happens-before的关系与内存一致性错误

    volatile与happens-before的关系与内存一致性错误

    本文讲了Java并发编程中volatile变量、happens-before与内存一致性错误,下面来和小编一起学习下如何解决
    2019-05-05

最新评论