NO.70 过滤器、监听器及线程安全问题

1.过滤器

(1)什么过滤器?

servlet规范当中定义的一种特殊的组件,用来拦截容器的调用过程。

  注:容器收到请求之后,如果有过滤器,则先调用过滤器,然后再调用servlet。

(2)如何写过滤器?

step1. 写一个java类,实现Filter接口。

step2. 在接口方法当中,实现拦截处理逻辑。

step3. 配置过滤器。

NO.70 过滤器、监听器及线程安全问题_第1张图片

(3)初始化参数

step1.配置初始化参数

NO.70 过滤器、监听器及线程安全问题_第2张图片

step2.调用FilterConfig提供的getInitParameter方法

(4)过滤器的优先级

当有多个过滤器都满足过滤的条件,则容器依据配置的先后顺序来执行。

代码示例:

NO.70 过滤器、监听器及线程安全问题_第3张图片

过滤器的优点(了解):

a.在不修改原有代码的基础上,为程序添加新的功能。

b.将多个模块相同的代码集中写在一个类里面,方便代码的维护。

2. 监听器

(1)什么是监听器?

servlet规范当中定义的一种特殊的组件,用来监听容器产生的事件并进行相应的处理。

  注:容器会产生两大类事件

1)生命周期相关的事件

容器创建或者销毁request,session,servlet上下文产生的事件。

2)绑订数据相关的事件

调用了request,session,servlet上下文的setAttribute,removeAttribute产生的事件。

(2)如何写监听器?

step1. 写一个java类,依据监听的事件类型来实现相应的接口。

比如,要监听session对象的创建和销毁,可以实现HttpSessionListener接口。

step2. 在监听器接口方法当中,实现监听处理逻辑。

step3. 配置监听器

NO.70 过滤器、监听器及线程安全问题_第4张图片

(3)Servlet上下文

1)Servlet上下文是什么?

容器启动之后,会为每一个web应用创建一个实现了ServletContext接口要求的对象,该对象可以称之为Servlet上下文。

特点:

a. 唯一性:一个web应用对应一个Servlet上下文。

b. 一直存在: 只要容器没有关闭,应用没有被卸载,Servlet上下文就会一直存在。

2)如何获取Servlet上下文?

GenericServlet,ServletConfig,HttpSession,FilterConfig都提供了一个方法(getServletContext)来获得Servlet上下文。

3)作用

a.绑定数据

setAttribute,removeAttribute,getAttribute

在满足使用条件的情况下,优先使用生命周期短的

(request < session < Servlet上下文)。

b.读取全局的初始化参数

代码示例:

NO.70 过滤器、监听器及线程安全问题_第5张图片

3. Servlet线程安全问题

(1)为什么说Servlet会有线程安全问题?

a.容器默认情况下,对于某个Servlet,只会创建一个实例。

b.容器收到请求,就会启动一个线程来处理,就有可能有多个线程同时访问同一个Servlet实例(比如,这些线程去修改Servlet的属性值),就有可能产生线程安全问题。

(2)如何解决?

a.加锁

使用synchronized对有线程安全问题的代码加锁。

b.尽量避免修改属性值

NO.70 过滤器、监听器及线程安全问题_第6张图片

代码示例:

NO.70 过滤器、监听器及线程安全问题_第7张图片

你可能感兴趣的:(NO.70 过滤器、监听器及线程安全问题)