一,Filter

FilterEncoding 过滤器,统一设置servlet的编码格式。

package com.dkt.filter;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse; public class FilterEncoding implements Filter{
private String encoding;
public void destroy() { } public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
request.setCharacterEncoding(encoding);
response.setCharacterEncoding(encoding);
chain.doFilter(request, response); } public void init(FilterConfig filterConfig) throws ServletException {
// encoding 在web.xml中配置。开启服务器即加载
encoding = filterConfig.getInitParameter("encoding");
System.out.println(encoding);
} }
FilterLogin 过滤器,访问页面时,过滤没有登录的用户,跳转到登录页面
package com.dkt.filter;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession; public class FilterLogin implements Filter{ public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest hrequest = (HttpServletRequest)request;
HttpSession session = hrequest.getSession();
Object name = session.getAttribute("name");
if (("").equals(name)||name==null) {
session.setAttribute("error", "*您还没有登录,请先登录");
/*
* 从goodsinfo文件夹下的goodsone页面中,跳转到loginFilter.jsp页面时,需向外跳一级
* request.getRequestDispatcher("../loginFilter.jsp").forward(request, response);
* 从WEB-INF文件下的userinfo文件夹下的userone.jsp页面跳到loginFilter.jsp页面。
* 需要向外跳两级。且WEB-INF文件夹的文件不能再外部通过http直接访问,
* 只能通过内部request的方式跳转页面
*/
//request.getRequestDispatcher("loginFilter.jsp").forward(request, response);
request.getRequestDispatcher("loginFilter.jsp").forward(request, response);
}else {
chain.doFilter(request, response);
}
} public void destroy() { } public void init(FilterConfig arg0) throws ServletException { } }

二,Listener

ListenerOnline 监听器,监听在线人数。并存在application作用域中
package com.dkt.listener;

import javax.servlet.http.HttpSession;
import javax.servlet.http.HttpSessionAttributeListener;
import javax.servlet.http.HttpSessionBindingEvent;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener; public class ListenerOnline implements HttpSessionAttributeListener,
HttpSessionListener{
private static int count;//统计在线人数 public void attributeAdded(HttpSessionBindingEvent se) {
HttpSession session = se.getSession();
Object username = session.getAttribute("name");
if (username!=null&&!("").equals(username)) {
count++;
session.getServletContext().setAttribute("count", count);
} } public void attributeRemoved(HttpSessionBindingEvent se) { } public void attributeReplaced(HttpSessionBindingEvent se) { } public void sessionCreated(HttpSessionEvent se) { } public void sessionDestroyed(HttpSessionEvent se) {
if (count>0) {
count--;
se.getSession().getServletContext().setAttribute("count", count);
}
} }
ListenerR 简单实用监听器
package com.dkt.listener;

import javax.servlet.ServletRequestAttributeEvent;
import javax.servlet.ServletRequestAttributeListener;
import javax.servlet.ServletRequestEvent;
import javax.servlet.ServletRequestListener; public class ListenerR implements ServletRequestAttributeListener,
ServletRequestListener{ public void attributeAdded(ServletRequestAttributeEvent srae) {
System.out.println("属性添加");
} public void attributeRemoved(ServletRequestAttributeEvent srae) {
System.out.println("属性移除");
} public void attributeReplaced(ServletRequestAttributeEvent srae) {
System.out.println("属性替换");
} public void requestDestroyed(ServletRequestEvent sre) {
System.out.println("销毁");
} public void requestInitialized(ServletRequestEvent sre) {
System.out.println("初始化");
} }

三,servlet

TestEncodingTwo 验证FilterEncoding 和 ListenerR 
package com.dkt.servlet;

import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; public class TestEncodingTwo extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { response.setContentType("text/html");
String name = request.getParameter("name");
String hobby = request.getParameter("hobby");
System.out.println(name+"----"+hobby);
request.setAttribute("name", name);
request.setAttribute("hobby", hobby);
/*
初始化
属性替换
销毁
初始化
属性替换
星星----男
属性添加
属性添加
销毁
*/
} }

  LoginServlet

package com.dkt.servlet;

import java.io.IOException;
import java.io.PrintWriter; import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession; import com.dkt.dao.UserJdbc; public class LoginServlet extends HttpServlet { public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doPost(request, response);
} public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException { response.setContentType("text/html");
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
HttpSession session = request.getSession();
String op = request.getParameter("op");
System.out.println("op----------->"+op);
if (("login").equals(op)) {
String name = request.getParameter("name");
String password = request.getParameter("password");
Boolean bool = new UserJdbc().validate(name, password);
if (bool) {
session.setAttribute("name", name);
request.getRequestDispatcher("/WEB-INF/userinfo/userone.jsp").forward(request, response);
}else {
request.getRequestDispatcher("../../loginFilter.jsp").forward(request, response);
}
}else if (("a").equals(op)) {
request.setAttribute("aaa", "apple");
PrintWriter out = response.getWriter();
out.print("apple");//responseText;
out.flush();
out.close();
}else if(("exit").equals(op)){
Object name = session.getAttribute("name");
session.invalidate();//销毁session
request.getRequestDispatcher("/WEB-INF/userinfo/userone.jsp").forward(request, response);
} } }  

四,jsp

loginFilter.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>"> <title>My JSP 'MyJsp.jsp' starting page</title> <meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
--> </head>
<body>
<form action="LoginServlet?op=login" method="post">
<span style="font-size: 12px;color: red;">${error }</span><br/>
用户名:<input type="text" name = "name" value=""><br/><br/>
密  码:<input type="password" name = "password" ><br/>
<input type="submit" value="登录">    
<input type="reset" value="重置"><br/>
</form>
<form action="LoginServlet?op=exit" method="post">
<input type="submit" value="退出" />
</form>
</body>
</html>

 index.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@page import="com.dkt.entity.UserInfo"%>
<%@ taglib uri="hello" prefix="hello" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>"> <title>My JSP 'index.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="This is my page">
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
</head> <body>
用户信息:${name }<br/>
当前在线人数:${count }
<hr/> </body>
</html>

  

 

五,web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <!-- 配置登录过滤器 -->
<filter>
<filter-name>loginfilter</filter-name>
<filter-class>com.dkt.filter.FilterLogin</filter-class>
</filter>
<!-- 过滤器适用于多个页面时,可重复多个filter-mappingm,以提供多个页面进行过滤 -->
<filter-mapping>
<filter-name>loginfilter</filter-name>
<url-pattern>/try.jsp</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>loginfilter</filter-name>
<url-pattern>/goodsinfo/*</url-pattern><!-- 过滤goodsinfo文件夹下的所有文件 -->
</filter-mapping>
<filter-mapping>
<filter-name>loginfilter</filter-name>
<url-pattern>/WEB-INF/userinfo/*</url-pattern><!-- 过滤WEB-INF文件夹下的userinfo文件夹下的所有文件 -->
</filter-mapping>
<filter-mapping>
<filter-name>loginfilter</filter-name>
<url-pattern>/FilterServlet</url-pattern><!-- 过滤servlet -->
</filter-mapping>
<!-- 当访问temp.jsp页面时会先执行过滤器,如果用户已登录则可访问
如果没用登录,session里面没有存name属性,则跳到登录页面,让用户登录.
登录成功在跳到temp.jsp
-->
<!-- 初始化过滤器,统一设置编码格式 -->
<filter>
<filter-name>filterEncoding</filter-name>
<filter-class>com.dkt.filter.FilterEncoding</filter-class>
<!-- 过滤初始化,设置servlet的编码格式 -->
<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>filterEncoding</filter-name>
<url-pattern>/servlet/*</url-pattern>
<!-- 过滤servlet下的所有servlet,初始化设置编码格式 此servlet下不是包名,是下面的mapping中的url-pattern路径 -->
</filter-mapping> <!-- request监听 -->
<listener>
<listener-class>com.dkt.listener.ListenerR</listener-class>
</listener>
<listener>
<listener-class>com.dkt.listener.ListenerOnline</listener-class>
</listener> <servlet>
<servlet-name>LoginServlet</servlet-name>
<servlet-class>com.dkt.servlet.LoginServlet</servlet-class>
</servlet>
<servlet>
<servlet-name>TestEncodingTwo</servlet-name>
<servlet-class>com.dkt.servlet.TestEncodingTwo</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>LoginServlet</servlet-name>
<url-pattern>/LoginServlet</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>TestEncodingTwo</servlet-name>
<url-pattern>/servlet/TestEncodingTwo</url-pattern>
</servlet-mapping> <welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>

  

java:Filter、Listener 自定义拦截器和过滤器应用的更多相关文章

  1. 面试题:struts 拦截器和过滤器

    拦截器和过滤器的区别 过滤器是servlet规范中的一部分,任何java web工程都可以使用. 拦截器是struts2框架自己的,只有使用了struts2框架的工程才能用. 过滤器在url-patt ...

  2. java 拦截器和过滤器区别(转载)

    1.拦截器是基于java的反射机制的,而过滤器是基于函数回调 2.过滤器依赖与servlet容器,而拦截器不依赖与servlet容器 3.拦截器只能对action请求起作用,而过滤器则可以对几乎所有的 ...

  3. java 中的拦截器和过滤器

    区别: 1.拦截器是基于java的反射机制的,而过滤器是基于函数回调 2.过滤器依赖与servlet容器,而拦截器不依赖与servlet容器 3.拦截器只能对action请求起作用,而过滤器则可以对几 ...

  4. Java Web 拦截器和过滤器的区别

    一.AOP:面向切面编程,Java Web中有两个常用的技术:拦截器.过滤器 二.拦截器 1.定义:在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作 2.原理:大部分时候,拦截器方法都 ...

  5. Spring Boot2(七):拦截器和过滤器

    一.前言 过滤器和拦截器两者都具有AOP的切面思想,关于aop切面,可以看上一篇文章.过滤器filter和拦截器interceptor都属于面向切面编程的具体实现. 二.过滤器 过滤器工作原理 从上图 ...

  6. Spring拦截器和过滤器

    什么是拦截器 拦截器(Interceptor): 用于在某个方法被访问之前进行拦截,然后在方法执行之前或之后加入某些操作,其实就是AOP的一种实现策略.它通过动态拦截Action调用的对象,允许开发者 ...

  7. SpringMVC学习笔记:拦截器和过滤器

    首先说明一下二者的区别: 1. 拦截器基于java的反射机制,而过滤器是基于函数回调 2. 拦截器不依赖于servlet容器,过滤器依赖servlet容器 3. 拦截器只能对action请求起作用,而 ...

  8. SpringBoot中拦截器和过滤器的使用

    一.拦截器 三种方式 继承WebMvcConfigurerAdapter   spring5.0 以弃用,不推荐 实现WebMvcConfigurer  推荐 继承WebMvcConfiguratio ...

  9. Spring boot 拦截器和过滤器

    1. 过滤器 Filter介绍 Filter可以认为是Servlet的一种“加强版”,是对Servlet的扩展(既可以对请求进行预处理,又可以对处理结果进行后续处理.使用Filter完整的一般流程是: ...

随机推荐

  1. 教你利用Node.js漏洞搞事情

    PentestingNode.js Application : Nodejs Application Security 原文地址:http://www.websecgeeks.com/2017/04/ ...

  2. express 重新加载

    1,res.location() 2. res.redirect() location()与redirect()的比较: Express的response对象,是对Node.js原生对象ServerR ...

  3. ansible 的第一次亲密接触

    如何添加一台机器 编辑 /etc/ansible/hosts 添加本机的 public ssh key 到目标机器的 authorized_keys 添加本机的 私钥 到 ansible 运行 ans ...

  4. VUE 项目刷新路由指向index.html

    背景描述: VUE 项目经过 npm run bulid 生成静态文件上传到服务器后,当我们切换路由并刷新页面,nginx 服务器会报 502 或者 404 错误. 原因分析: 我猜测是因为在 VUE ...

  5. sublime text 内调试Javascript代码

    转自:sublime内调试Javascript代码 之前用webstorm, 可以直接调试js, 在浏览器中也可以调试js,最近换了sublime text, 在想它是否支持调试js代码,于是找到了这 ...

  6. 【Git】学习记录

    配置git git config --global user.name "用户名或者用户ID" git config --global user.email "邮箱&qu ...

  7. 编译Qt-mingw使用的opencv

    set path=D:\dev\IDE\Qt5.7.0\Tools\mingw530_32\bin;%path% cd build_mingw530_32 cmake -G "MinGW M ...

  8. 前端通信:ajax设计方案(四)--- 集成ajax上传技术 大文件/超大文件前端切割上传,后端进行重组

    马上要过年了,哎,回家的心情也特别的激烈.有钱没钱,回家过年,家永远是舔舐伤口最好的地方.新的一年继续加油努力. 上次做了前端的ajax的上传文件技术,支持单文件,多文件上传,并对文件的格式和大小进行 ...

  9. spring整合elasticsearch之环境搭建

    推荐一个非常好的博客: 点我 // 测试使用docker下启动的es不管用, 在linux下或者windows下运行的es可用 // 进一步测试docker下启动的es链接时, 开启嗅探也链接不上, ...

  10. jquery完全版下载

    查看演示立刻下载错误提交填加用法   jquery-2.1.1 (注!jquery-2.0以上版本不再支持IE 6/7/8) 百度引用地址 (推荐目前最稳定的,不会出现延时打不开情况) 百度压缩版引用 ...