Java Web 过滤器和监听器

Servlet的作用是针对浏览器发起的请求,进行请求的处理,通过Servlet技术我们可以灵活的进行请求的处理,但是我们不但要对请求进行处理,我们还需要对服务器的资源进行管理,比如,统一设置编码格式,资源的统一分配等。。。这个时候该怎么办呢?
解决:
使用过滤器
作用:
1.对服务器资源进行管理
2.保护Servlet
使用:
1.创建一个实现了Filter接口的普通类
2.覆写接口的方法
      init方法:服务器启动就执行,资源初始化
      doFilter方法:拦截请求的方法,此方法中可以对资源实现管理
        注意:这个需要手动对请求进行放行。
      destory()方法:服务器关闭才执行

public class filter1 implements Filter {
	public void init(FilterConfig arg0) throws ServletException {
		System.out.println("filter1.init()我被初始化了!");
	}

	public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain)
			throws IOException, ServletException {
		System.out.println("filter1.doFilter()我被调用了");// 过滤的方法
		chain.doFilter(req, resp);// 过滤后,将请求放行
		System.out.println("filter1.doFilter()我又被调用了");
		// 请求执行后,响应浏览器的时候,再过滤一次
	}

	// 当服务器关闭时,会执行destory这个方法
	public void destroy() {
		System.out.println("filter1.destroy()我被销毁了!");
	}

}

3.在web.xml中配置过滤器
与配置servlet一致,样式也都一样,没有什么特别要注意的。
代码:

 <!-- 配置过滤器 -->
  <filter>
    <filter-name>myfilter</filter-name>
    <filter-class>Filter.filter1</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>myfilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
  

注意:
url-pattern : /* 表示拦截了所有的请求
url-pattern: *.do 表示所有以.do结尾的请求。
url-pattern: /ts 表示拦截指定url的请求,针对某个servlet的请求进行拦截,保护servlet
过滤器的生命周期:
服务器启动到服务器关闭。
总结:
过滤器由程序员声明和配置,服务器根据请求中的uri信息进行调用。
执行:
浏览器发起请求到服务器,服务器接收到请求后,根据URI信息在web.xml中找到对用户的过滤器执行doFilter方法,该方法对此次请求进行处理后,如果符合要求则放行,放行后,如果还有符合要求的过滤则继续过滤,找到执行对应的servlet进行请求处理,servlet对请求处理完毕后,也就是service方法结束了,还需继续返回响应的doFilter方法继续执行。
案例:
统一管理字符编码格式
session管理
权限管理
资源管理(统一水印,和谐词汇等)


我是一条没有感情的分割线


监听器:
概念:servlet监听器是Servlet规范定义的一种特殊类,用于监听ServletContext,HttpSession和ServletRequest等域对象的创建与销毁事件,以及监听这些域对象属性发生修改的事件。
监听器:
request,session,application
监听内容:
创建、销毁、属性改变事件
监听作用:在事件发生之前,之后进行处理,比如统计在线人数
监听器的使用:
作用:监听作用域对象的request、session、application的创建、销毁和内容的改变。
使用:
创建一个实现了指定接口类的java类

监听request对象
----->ServletRequestListener 监听request对象的创建和销毁
    requestDestroyed(ServletRequestEvent sre)//创建
    requestInitialized(ServletRequestEvent sre)//销毁
注意:形参可以获得监听的request对象
    sre.getServletRequest();;

----->ServletRequestAttributeListener 监听request作用域数据的变更
    attributeAdded(ServletRequestAttributeEvent srae)
    attributeRemoved(ServletRequestAttributeEvent srae)
    attributeReplaced(ServletRequestAttributeEvent srae)
    注意:形参可以获得被监听的数据
        sare.getName(); 获取监听数据的键
        sare.getValue(); 获取监听数据的值

	public void attributeAdded(ServletRequestAttributeEvent srae) {
		srae.getName();// 获得增加的request对象的名字
		srae.getValue();// 获得增加的request对象的值
	}
	@Override
	public void attributeRemoved(ServletRequestAttributeEvent srae) {
		srae.getServletContext();
	}

监听session对象
--------->HttpSessionListener监听session对象的创建和销毁
    sessionCreated(HttpSessionEvent se)//创建
    sessionDestroyed(HttpSessionEvent se)//销毁
    注意:形参可以获得监听的session对象
          se.getSession();
-------->HttpSessionAttributeListener 监听session对象作用域数据的变更
attributeAdded(ServletRequestAttributeEvent srae)
    attributeAdded(HttpSessionBindingEvent arg0)
    attributeRemoved(HttpSessionBindingEvent arg0)
    attributeReplaced(HttpSessionBindingEvent arg0)
    注意:形参可以获得被监听的数据
     se.getName();
     se.getClass();
session对象和request对象相类似,也可以通过类创建的对象,也有方法可以获得创建和销毁的对象,也可以获得新增,删除,修改的数据

监听ServletContext对象
------>ServletContextListener 监听ServletContext对象的创建和销毁
    attributeAdded(ServletContextAttributeEvent scab)//创建
    attributeRemoved(ServletContextAttributeEvent scab)//销毁
注意:形参能够获得该ServletContext对象
------>ServletContextAttributeListener 监听ServletContext作用域数据的变更
    attributeReplaced(ServletContextAttributeEvent scab)
    contextDestroyed(ServletContextEvent scab)
    contextInitialized(ServletContextEvent scab)
注意:形参可以获得ServletContext的数据


配置web.xml文件

  <listener>
  <listener-class>Listener.listener1</listener-class>
  </listener>

注意:只需要配置一个标签即可。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值