java:Filter、Listener 自定义拦截器和过滤器应用
一,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 自定义拦截器和过滤器应用的更多相关文章
- 面试题:struts 拦截器和过滤器
拦截器和过滤器的区别 过滤器是servlet规范中的一部分,任何java web工程都可以使用. 拦截器是struts2框架自己的,只有使用了struts2框架的工程才能用. 过滤器在url-patt ...
- java 拦截器和过滤器区别(转载)
1.拦截器是基于java的反射机制的,而过滤器是基于函数回调 2.过滤器依赖与servlet容器,而拦截器不依赖与servlet容器 3.拦截器只能对action请求起作用,而过滤器则可以对几乎所有的 ...
- java 中的拦截器和过滤器
区别: 1.拦截器是基于java的反射机制的,而过滤器是基于函数回调 2.过滤器依赖与servlet容器,而拦截器不依赖与servlet容器 3.拦截器只能对action请求起作用,而过滤器则可以对几 ...
- Java Web 拦截器和过滤器的区别
一.AOP:面向切面编程,Java Web中有两个常用的技术:拦截器.过滤器 二.拦截器 1.定义:在某个方法或字段被访问之前,进行拦截然后在之前或之后加入某些操作 2.原理:大部分时候,拦截器方法都 ...
- Spring Boot2(七):拦截器和过滤器
一.前言 过滤器和拦截器两者都具有AOP的切面思想,关于aop切面,可以看上一篇文章.过滤器filter和拦截器interceptor都属于面向切面编程的具体实现. 二.过滤器 过滤器工作原理 从上图 ...
- Spring拦截器和过滤器
什么是拦截器 拦截器(Interceptor): 用于在某个方法被访问之前进行拦截,然后在方法执行之前或之后加入某些操作,其实就是AOP的一种实现策略.它通过动态拦截Action调用的对象,允许开发者 ...
- SpringMVC学习笔记:拦截器和过滤器
首先说明一下二者的区别: 1. 拦截器基于java的反射机制,而过滤器是基于函数回调 2. 拦截器不依赖于servlet容器,过滤器依赖servlet容器 3. 拦截器只能对action请求起作用,而 ...
- SpringBoot中拦截器和过滤器的使用
一.拦截器 三种方式 继承WebMvcConfigurerAdapter spring5.0 以弃用,不推荐 实现WebMvcConfigurer 推荐 继承WebMvcConfiguratio ...
- Spring boot 拦截器和过滤器
1. 过滤器 Filter介绍 Filter可以认为是Servlet的一种“加强版”,是对Servlet的扩展(既可以对请求进行预处理,又可以对处理结果进行后续处理.使用Filter完整的一般流程是: ...
随机推荐
- FunDA(7)- Reactive Streams to fs2 Pull Streams
Reactive-Stream不只是简单的push-model-stream, 它还带有“拖式”(pull-model)性质.这是因为在Iteratee模式里虽然理论上由Enumerator负责主动推 ...
- 盗墓笔记—阿里旺旺ActiveX控件imageMan.dll栈溢出漏洞研究
本文作者:i春秋作家——cq5f7a075d 也许现在还研究Activex就是挖坟,但是呢,笔者是摸金校尉,挖坟,呸!盗墓是笔者的本职工作. 额,不扯了,本次研究的是阿里旺旺ActiveX控件imag ...
- ReentrantLock锁的释放
一:代码 reentrantLock.unlock(); 虽然只有一句,但是源码却比较多: public final boolean release(int arg) { if (tryRelease ...
- JavaScript 函数的4种调用方法
JavaScript 函数有 4 种调用方式. 每种方式的不同方式在于 this 的初始化. 作为一个函数调用 function myFunction(a, b) { return a * b; } ...
- jq02--基础函数
jq是一个js函数库,主要是为事件处理特别设计的,现在我们继续学习一些jq函数. 1.jq效果: 显示与隐藏: $().hide(speed,callback) speed--"slow&q ...
- 解决Mysql Workbench的Error Code: 1175错误 无法删除数据
使用workbench,如果你要批量更新或删除数据,一般会报“ Error Code: 1175 You are using safe update mode and you tried to upd ...
- Spring Security构建Rest服务-0400-使用切片拦截rest服务
Restful API的拦截: 1,过滤器(Filter) 2,拦截器(Interceptor) 3,切片(Aspect) 1,过滤器 和传统javaweb一鸟样,例,记录controller执行时间 ...
- IDEA Community(社区版)再谈之无奈之下还是去安装旗舰版
不多说,直接上干货! 前言 相信很多人,跟我一样,一开始,接触spark,肯定会首选IntelliJ IDEA的社区版Community. IntelliJ IDEA号称当前Java开发效率最高的ID ...
- asp.net六种方法刷新页面
第一: private void Button1_Click( object sender, System.EventArgs e ) { Response.Redirect( Reque ...
- react config test env with jest and create-react-app 1
/.babelrc { "presets": ["@babel/preset-env","@babel/preset-react"], &q ...