Listener监听器与web.xml相关配置

简介:

 在JavaWeb中有个叫监听器的东西,这监听器主要用来监听三大对象:HttpServletRequest、HttpSession、ServletContext,每个对象对应着各自的监听器接口。监听器可以监听这三个对象中的对象创建、初始化与销毁信息的事件,也可以监听对象中的属性变更信息的事件,例如对象的属性添加或删除属性等变更信息。
所以会有六个主要的监听器接口,ServletRequestListener、ServletContextListener和HttpSessionListener接口是用于监听对象的创建与销毁信息。
ServletContextAttributeListener, HttpSessionAttributeListener 和ServletRequestAttributeListener,这三个接口则是定义了三个方法来处理被监听对象中的属性的增加,删除和替换的事件,同一个事件在这三个接口中对应的方法名称完全相同,只是接受的参数类型不同。
配置监听器的方式有两种,第一种是以注解的方式配置,第二种则是以web.xml文件的方式配置。参考以下示例:
使用注解配置监听器:
Listener监听器与web.xml相关配置
使用注解的方式配置监听器很简单,实现一个或多个监听器接口,然后写上@WebListener注解即可。

<br>
使用web.xml文件配置监听器:
Listener监听器与web.xml相关配置

<br>
代码:
Listener监听器与web.xml相关配置
以上代码只是实现了监听Session对象的接口,此接口可以监听对象的创建和销毁,然后编写一个Servlet类来测试一下是否能正常监听,代码示例:
Listener监听器与web.xml相关配置

<br>
运行结果:
Listener监听器与web.xml相关配置
由于以上示例中我使用注解和web.xml的方式配置了两个监听器,所以一个session对象被两个监听器所监听了。

<br>
以下演示其他两个监听器接口:
ServletRequestListener接口:
Listener监听器与web.xml相关配置

<br>
运行结果:
Listener监听器与web.xml相关配置

<br>
ServletContextListener接口:
Listener监听器与web.xml相关配置

<br>
运行结果:
Listener监听器与web.xml相关配置
Listener监听器与web.xml相关配置
如图,由于ServletContext是服务器启动时就创建,服务器关闭时才销毁,所以只有在这两种情况下才能监听到ServletContext对象的创建和销毁。

<br>
以上演示的是监听对象的创建与销毁的三个接口,下面我们再来看一下监听对象属性的三个接口:
HttpSessionAttributeListener接口:
Listener监听器与web.xml相关配置

<br>
Servlet代码:
Listener监听器与web.xml相关配置

<br>
运行结果:
Listener监听器与web.xml相关配置
如图,可以看到session对象销毁后,会把属性给删除掉,并且这个过程会被监听器监听,所以监听器还能帮助我们查看这些对象的一些规律和顺序。

<br>
ServletRequestAttributeListener接口:
Listener监听器与web.xml相关配置

<br>
Servlet代码:
Listener监听器与web.xml相关配置

<br>
运行结果:
Listener监听器与web.xml相关配置

<br>
ServletContextAttributeListener接口:
Listener监听器与web.xml相关配置

<br>
Servlet代码:
Listener监听器与web.xml相关配置

<br>
运行结果:
Listener监听器与web.xml相关配置

<br><br><br>

web.xml相关配置


配置默认页面,这个转发机制会让你看不到URL地址的变动:
Listener监听器与web.xml相关配置

web.xml中默认会配置为以index、default为文件名前缀的.jsp或者.html文件。所以只要你的工程目录下有一个名称与上图中配置的文件名称一样的文件的话,那么当你访问这个web工程的时候,就会默认访问这个文件。

<br>
例如我在web工程目录下创建一个index.jsp,然后再浏览器上访问这个web工程:
Listener监听器与web.xml相关配置

<br>
浏览器访问:
Listener监听器与web.xml相关配置

<br>
如图,可以看到URL地址没有发生任何变动,但是却访问到了这个index.jsp上,平时我们访问某个网站域名的时候,也是访问到这样的一个默认页,但是URL上不会有所变动,这就是这种转发机制的特殊之处。

<br><br>
配置发生http错误状态码后跳转的页面:


Listener监听器与web.xml相关配置
当发生404错误的时候,就跳转到根目录下的404.html文件上。

<br><br>
配置session的过期时间与ID名称:


Listener监听器与web.xml相关配置

<br><br>
ServletContext对象初始化参数配置:


Listener监听器与web.xml相关配置
可以配置多个context-param标签,param-name配置参数的名称,param-value配置参数的值,这两个标签需要配置在context-param标签内。



本文转自 ZeroOne01 51CTO博客,原文链接:http://blog.51cto.com/zero01/2044400,如需转载请自行联系原作者

相关文章
|
3月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
63 4
|
16天前
|
XML Java 数据格式
Spring容器Bean之XML配置方式
通过对以上内容的掌握,开发人员可以灵活地使用Spring的XML配置方式来管理应用程序的Bean,提高代码的模块化和可维护性。
53 6
|
5月前
【Azure 应用服务】Web App Service 中的 应用程序配置(Application Setting) 怎么获取key vault中的值
【Azure 应用服务】Web App Service 中的 应用程序配置(Application Setting) 怎么获取key vault中的值
|
2月前
|
JavaScript 前端开发 开发工具
web项目规范配置(husky、eslint、lint-staged、commit)
通过上述配置,可以确保在Web项目开发过程中自动进行代码质量检查和规范化提交。Husky、ESLint、lint-staged和Commitlint共同作用,使得每次提交代码之前都会自动检查代码风格和语法问题,防止不符合规范的代码进入代码库。这不仅提高了代码质量,还保证了团队协作中的一致性。希望这些配置指南能帮助你建立高效的开发流程。
55 5
|
4月前
|
XML Java 数据格式
Spring IOC—基于XML配置Bean的更多内容和细节(通俗易懂)
Spring 第二节内容补充 关于Bean配置的更多内容和细节 万字详解!
285 18
|
4月前
|
小程序 前端开发 中间件
ThinkPHP 配置跨域请求,使用TP的内置跨域类配置,小程序和web网页跨域请求的区别及格式说明
本文介绍了如何在ThinkPHP框架中配置跨域请求,使用了TP内置的跨域类`\think\middleware\AllowCrossDomain::class`。文章还讨论了小程序和web网页在跨域请求格式上的区别,并提供了解决方案,包括修改跨域中间件源码以支持`Origin`和`token`。此外,还介绍了微信小程序跨域请求的示例和web网页前端发送Axios跨域请求的请求拦截器配置。
ThinkPHP 配置跨域请求,使用TP的内置跨域类配置,小程序和web网页跨域请求的区别及格式说明
|
4月前
|
XML Java 应用服务中间件
springMVC01,springMVC的执行流程【第一个springMVC例子(XML配置版本):HelloWorld】
通过一个HelloWorld实例,介绍了SpringMVC的基本概念、执行流程,并详细讲解了如何创建和配置第一个SpringMVC项目(基于XML)。
springMVC01,springMVC的执行流程【第一个springMVC例子(XML配置版本):HelloWorld】
|
3月前
|
XML 分布式计算 资源调度
大数据-02-Hadoop集群 XML配置 超详细 core-site.xml hdfs-site.xml 3节点云服务器 2C4G HDFS Yarn MapRedece(一)
大数据-02-Hadoop集群 XML配置 超详细 core-site.xml hdfs-site.xml 3节点云服务器 2C4G HDFS Yarn MapRedece(一)
205 5
|
3月前
|
XML 资源调度 网络协议
大数据-02-Hadoop集群 XML配置 超详细 core-site.xml hdfs-site.xml 3节点云服务器 2C4G HDFS Yarn MapRedece(二)
大数据-02-Hadoop集群 XML配置 超详细 core-site.xml hdfs-site.xml 3节点云服务器 2C4G HDFS Yarn MapRedece(二)
171 4
|
3月前
|
分布式计算 资源调度 Hadoop
大数据-01-基础环境搭建 超详细 Hadoop Java 环境变量 3节点云服务器 2C4G XML 集群配置 HDFS Yarn MapRedece
大数据-01-基础环境搭建 超详细 Hadoop Java 环境变量 3节点云服务器 2C4G XML 集群配置 HDFS Yarn MapRedece
103 4