一.过滤器
定义: 过滤器是处于客户端与服务器资源文件之间的一道过滤网,在访问资源文件之前,通过一系列的过滤器对请求进行修改、判断等,把不符合规则的请求在中途拦截或修改。也可以对响应进行过滤,拦截或修改响应。
过滤器一般用于登录权限验证、资源访问权限控制、敏感词汇过滤、字符编码转换等等操作,便于代码重用,不必每个servlet中还要进行相应的操作。
实现Filter过滤器
1.新建普通java类
2.实现Filter接口
3.实现接口中的方法
4.设置web.xml的配置文件
注意: 在配置中需要注意的有两处:一是指明过滤器类所在的包路径。二是处定义过滤器作用的对象。一般有以下规则:
1.作用与所有web资源:<url—pattern>/。则客户端请求访问任意资源文件时都要经过过滤器过滤,通过则访问文件,否则拦截。
2.作用于某一文件夹下所有文件:<url—pattern>/dir/
3.作用于某一种类型的文件:<url—pattern>.扩展名。比如<url—pattern>.jsp过滤所有对jsp文件的访问请求。
4.作用于某一文件夹下某一类型文件:<url—pattern>/dir/*.扩展名
如果一个过滤器需要过滤多种文件,则可以配置多个,一个mapping定义一个url-pattern来定义过滤规则。
5.放行: doFilter(request, response)
二. Web监听器
1.什么是web监听器?
web监听器是一种Servlet中的特殊的类,它们能帮助开发者监听web中的特定事件,比如ServletContext,HttpSession,ServletRequest的创建和销毁;变量的创建、销毁和修改等。可以在某些动作前后增加处理,实现监控。
2. 监听器常用的用途
通常使用Web监听器做以下的内容:
统计在线人数,利用HttpSessionLisener
加载初始化信息:利用ServletContextListener
统计网站访问量
实现访问监控
3.web如何显示在线人数例:
第一步public class MyListener implements HttpSessionListener{
private int userNumber = 0;
public void sessionCreated(HttpSessionEvent arg0) {
userNumber++;
arg0.getSession().setAttribute(“userNumber”, userNumber);
}
public void sessionDestroyed(HttpSessionEvent arg0) {
userNumber–;
arg0.getSession().setAttribute(“userNumber”, userNumber);
}
}
第二步在web.xml中配置该监听器,在web-app中添加:
com.test.MyListener
在JSP中添加访问人数:
过滤器监听器
最新推荐文章于 2024-07-14 18:12:37 发布