目录
1.过滤器
1.1 什么是过滤器
过滤器是一个对象,可以传输请求或修改响应。它可以在请求到达Servlet/JSP之前对其进行预处理,而且能够在响应离开Servlet /JSP之后对其进行后处理。所以如果你有几个Servlet/JSP需要执行同样的数据转换或页面处理的话,你就可以写一个过滤器类,然后在部署描述文 件(web.xml)中把该过滤器与对应的Servlet/JSP联系起来。你可以一个过滤器以作用于一个或一组servlet,零个或多个过滤器能过滤 一个或多个servlet
1.2 实现接口 java.servlet.Filter
一个过滤器实现 Filter 接口并定义它的三个方法:
1.void init(FilterConfig config) throws ServletException:在过滤器执行service前被调用,以设置过滤器的配置对象。
2.void destroy();在过滤器执行service后被调用。
3.void doFilter(ServletRequest req,ServletResponse res,FilterChain chain) throws IOException,ServletException;
1.3 配置web
<!-- 配置过滤器 -->
<!-- <filter>
<filter-name>myFiler</filter-name>
<filter-class>com.zking.filer.myFiler</filter-class>
配置过滤器初始化参数
参数1
<init-param>
<param-name>name</param-name>
<param-value>张三</param-value>
</init-param>
参数2
<init-param>
<param-name>sex</param-name>
<param-value>男</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>myFiler</filter-name>
设置过滤器要过滤的请求
过滤访问shop.jsp的请求
<url-pattern>/shop.jsp</url-pattern>
<url-pattern>/shop2.jsp</url-pattern>
过滤指定后缀名的请求
<url-pattern>*.jsp</url-pattern>
过滤器指定目录的请求
<url-pattern>/admin/shop.jsp</url-pattern>
过滤整个项目所有请求,包括了所有的后缀
<url-pattern>/*</url-pattern>
</filter-mapping> -->
1.4 设置编码,登录验证
@Override
public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2) throws IOException, ServletException {
// 转换参数类型 arg0和arg1
HttpServletResponse resp = (HttpServletResponse)arg0;
HttpServletRequest req = (HttpServletRequest)arg1;
PrintWriter out = resp.getWriter();
//设置编码
resp.setContentType("text/html;charset=utf-8");
req.setCharacterEncoding("utf-8");
//访问登录页面的请求不被过滤
//获取过滤器所拦截的请求,什么请求?
String uriPath = req.getRequestURI();
//indexOf("要查找的字符串") 如果找不到返回-1
if (uriPath.indexOf("shop.jsp") != -1) {//找到了,则该请求是访问shop.jsp
// 放行/继续前进
arg2.doFilter(arg0, arg1);
}
//登录验证
//获取session
HttpSession session = req.getSession();
//获取session里面保存的uname
Object uname = session.getAttribute("uname");
if (null != uname) {//已经登录,则访问
// 放行/继续前进
arg2.doFilter(arg0, arg1);
}else {//没有登录
out.print("<script>alert('请先登录!');location.href='"+req.getContextPath()+"/home/login.jsp'</script>");
}
// System.out.println("请求被过滤器拦截!");
}
2.监听器
2.1 什么是监听器
web监听器是一种Servlet中的特殊的类,它们能帮助开发者监听web中的特定事件,比如ServletContext,HttpSession,ServletRequest的创建和销毁;变量的创建、销毁和修改等。可以在某些动作前后增加处理,实现监控。
2.2 监听器常用的用途
统计在线人数,利用HttpSessionLisener
加载初始化信息:利用ServletContextListener
统计网站访问量
实现访问监控
2.3 在web.xml中配置监听器
<listenner>
<listenner-class> listenner的实现类 </listenner-class>
</listenner>
2.4 实现统计人数
实现 ServletContextListener,HttpSessionListener 接口
@Override
public void sessionCreated(HttpSessionEvent arg0) {
//System.out.println("会话被创建");
ServletContext application = arg0.getSession().getServletContext();
Integer count =(Integer)application.getAttribute("count");
if(null == count){// 在第一个人访问之前没有人在线
count = 1;//添加第一个人的访问}else {// 在你访问之前已经有人在线
}else {
count ++;//统计当前这个人的访问次数
}
//最后再把访问次数添加到application作用域里面
application.setAttribute("count", count);
}
@Override
public void sessionDestroyed(HttpSessionEvent arg0) {
//System.out.println("会话被撤销");
ServletContext application = arg0.getSession().getServletContext();
Integer count =(Integer)application.getAttribute("count");
count --;//统计当前这个人的访问次数
//最后再把访问次数添加到application作用域里面
application.setAttribute("count", count);
}
访问人数
你是第:${count }个用户!