①过滤器
在src里面建一个filter包:
主要字符编码过滤器的代码如下(记得实现Filter类):
@Override
public void destroy() {
// TODO Auto-generated method stub
//销毁
}
@Override
public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2)
throws IOException, ServletException {
/**
* URL通配符:以下两种情况任选其一
* 1. /*:所有的界面(请求)
* 2. *.后缀 (例如*.do:所有以do为后缀的请求)
*/
HttpServletRequest req=(HttpServletRequest)arg0;
//设置编码方式
req.setCharacterEncoding("utf-8");
//获取请求路径 equals 上下文参数
String path=req.getServletPath();
System.out.println("请求路径:"+path);
//执行过滤操作
System.out.println("经过了字符编码过滤器~~我得意的笑");
//执行放行操作
arg2.doFilter(arg0, arg1);
}
@Override
public void init(FilterConfig arg0) throws ServletException {
// TODO Auto-generated method stub
//初始化
}
②监听器
主要功能是负责监听Web的各种操作,当相关的事件触发后将产生事件,并对事件进行处理。
监听器分为3种:
application 监听器(常用)
session 监听器(偶尔用)
request 监听器(不用,性能差)
小知识:为什么说session监听器和request监听器一般都不用?
答:以request监听器为例,如果采用request监听,那就意味着每次请求都要触发一次监 听,这大大降低了程序的效率,因此很少用。
案例:使用监听器实现统计在线人数:
/**
* 创建一个会话 +1
* 销毁一个会话 -1
*/
//application:应用
private ServletContext application=null;//扩大作用域
@Override
public void contextDestroyed(ServletContextEvent arg0) {
// System.out.println("应用程序被销毁了");
}
@Override
public void contextInitialized(ServletContextEvent arg0) {
// System.out.println("应用程序被初始化了");
//初始化的时候赋值
application=arg0.getServletContext();
Integer count = 0;
//存进去
application.setAttribute("count", count);//键,值 ${count}
}
@Override
public void sessionCreated(HttpSessionEvent arg0) {
// System.out.println("会话被创建了");
//在原来的基础上+1
//先拿值 +1 再存进去
Integer count=(Integer)application.getAttribute("count");//先拿到之前的在线人数
count++;
application.setAttribute("count", count);
}
@Override
public void sessionDestroyed(HttpSessionEvent arg0) {
// System.out.println("会话被销毁了-注销");
//在原来的基础上-1
//先拿值 -1 再存进去
Integer count=(Integer)application.getAttribute("count");//先拿到之前的在线人数
count--;
application.setAttribute("count", count);
}