Spring MVC - 拦截器实现 和 用户登陆例子
1.拦截器
SpringMvc中的拦截器实现了HandlerInterceptor接口,通常使用与身份认证,授权和校验,模板视图,统一处理等;
- public class HanderInterceptor1 implements HandlerInterceptor {
- @Override
- public void afterCompletion(HttpServletRequest arg0,
- HttpServletResponse arg1, Object arg2, Exception arg3)
- throws Exception {
- }
- @Override
- public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
- Object arg2, ModelAndView arg3) throws Exception {
- }
- @Override
- public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,
- Object arg2) throws Exception {
- return true;
- }
- }
在拦截器中中有三个方法 :
preHandler :在进入Handler方法之前执行了,使用于身份认证,身份授权,登陆校验等,比如身份认证,用户没有登陆,拦截不再向下执行,返回值为 false ,即可实现拦截;否则,返回true时,拦截不进行执行;
postHandler : 进入Handler方法之后,返回ModelAndView之前执行,使用场景从ModelAndView参数出发,比如,将公用的模型数据在这里传入到视图,也可以统一指定显示的视图等;
afterHandler : 在执行Handler完成后执行此方法,使用于统一的异常处理,统一的日志处理等;
2.拦截器的配置
拦截器的配置有两种方式实现 :
(1)针对某个handlermapping (controller)的 配置
Springmvc拦截器针对某个controller进行拦截设置,如果在某个HandlerMapping中配置拦截,经过该HandlerMapping映射成功的handler最终使用该拦截器;
(2)类似全局的配置
可以配置类似全局的拦截器,springmvc框架将配置的类似全局拦截器注入到每个Handlermapping中;
配置实现 :
- <!-- 配置拦截器 -->
- <mvc:interceptors>
- <!-- 多个拦截器,顺序执行 -->
- <mvc:interceptor>
- <!-- /** 表示所有的url,包括子url路径 -->
- <mvc:mapping path="/**"/>
- <bean class="cn.labelnet.ssm.filter.HanderInterceptor1"></bean>
- </mvc:interceptor>
- <!-- 配置登陆拦截器 -->
- <mvc:interceptor>
- <mvc:mapping path="/**"/>
- <bean class="cn.labelnet.ssm.filter.LoginHandlerIntercepter"></bean>
- </mvc:interceptor>
- <!--
- .....
- -->
- </mvc:interceptors>
(3)在一个工程中,可以配置多个拦截器,使用多个拦截器,则要注意的是 :
多个拦截器使用的时候,preHandler是顺序执行的,而postHandler和afterHandler是倒序执行的;
所以 :
如果统一日志处理器拦截器,需要改拦截器prehandler一定要返回true,且将它放在拦截器配置的第一个位置;
如果登陆认证拦截器,放在拦截器的配置中的第一个位置(有日志处理的话,放在日志处理下面);
如果有权限校验拦截器,则放在登陆拦截器之后,因为登陆通过后,才可以进行校验权限;
3.示例:
场景描述 :用户点击查看的时候,我们进行登陆拦截器操作,判断用户是否登陆? 登陆,则不拦截,没登陆,则转到登陆界面;
图示 :
3.1 controller 登陆业务实现
- @RequestMapping("/clientLogin")
- public String clientLogin(HttpSession httpSession,String username,String password){
- if(username.equals("yuan")&&password.equals("123456")){
- //登陆成功
- httpSession.setAttribute("username",username);
- return "forward:clientsList.action";
- }else{
- //登陆失败
- return "forward:login.jsp";
- }
- }
3.2 controller 登出业务实现
- @RequestMapping("/clientLoginOut")
- public String clientLoginOut(HttpSession httpSession){
- httpSession.invalidate();
- return "forward:clientsList.action";
- }
3.3 拦截器实现
在这里实现用户拦截实现是:通过判断是否是编辑查看的页面,如果是,判断session中的用户名存在不存在,就可以了;
- package cn.labelnet.ssm.filter;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import javax.servlet.http.HttpSession;
- import org.springframework.web.servlet.HandlerInterceptor;
- import org.springframework.web.servlet.ModelAndView;
- /**
- * 登陆拦截器
- * 场景:用户点击查看的时候,我们进行登陆拦截器操作,判断用户是否登陆?
- * 登陆,则不拦截,没登陆,则转到登陆界面;
- * TODO
- * 作者:原明卓
- * 时间:2016年1月8日 下午3:25:35
- * 工程:SpringMvcMybatis1Demo
- */
- public class LoginHandlerIntercepter implements HandlerInterceptor {
- @Override
- public void afterCompletion(HttpServletRequest request,
- HttpServletResponse response, Object arg2, Exception arg3)
- throws Exception {
- }
- @Override
- public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
- Object arg2, ModelAndView arg3) throws Exception {
- }
- @Override
- public boolean preHandle(HttpServletRequest request, HttpServletResponse arg1,
- Object arg2) throws Exception {
- String requestURI = request.getRequestURI();
- if(requestURI.indexOf("editClientIfo.action")>0){
- //说明处在编辑的页面
- HttpSession session = request.getSession();
- String username = (String) session.getAttribute("username");
- if(username!=null){
- //登陆成功的用户
- return true;
- }else{
- //没有登陆,转向登陆界面
- request.getRequestDispatcher("/login.jsp").forward(request,arg1);
- return false;
- }
- }else{
- return true;
- }
- }
- }
3.4 拦截器配置实现
- <!-- 配置拦截器 -->
- <mvc:interceptors>
- <!-- 多个拦截器,顺序执行 -->
- <mvc:interceptor>
- <!-- /** 表示所有的url,包括子url路径 -->
- <mvc:mapping path="/**"/>
- <bean class="cn.labelnet.ssm.filter.HanderInterceptor1"></bean>
- </mvc:interceptor>
- <!-- 配置登陆拦截器 -->
- <mvc:interceptor>
- <mvc:mapping path="/**"/>
- <bean class="cn.labelnet.ssm.filter.LoginHandlerIntercepter"></bean>
- </mvc:interceptor>
- <!--
- .....
- -->
- </mvc:interceptors>
3.5 登陆页面实现
- <%@ 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>用户登陆</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="${pageContext.request.contextPath }/clients/clientLogin.action" method="post">
- 姓名:<input type="text" name="username"> <br><br>
- 密码: <input type="text" name="password"> <br><br>
- <input type="submit" value="登陆">
- </form>
- </body>
- </html>
3.6 列表信息页面
- <body>
- <h1>客户信息管理 <br>
- <c:if test="${username!=null }">
- ${username}
- <a href="${pageContext.request.contextPath}/clients/clientLoginOut.action">退出</a>
- </c:if>
- </h1>
- <form method="post" action="" style="margin-top: 10px;float: left;margin-left: 5%;">
- <input id="search" type="text" >
- <input value="查询" type="submit">
- </form>
- <table width="90%" border="1" align="center">
- <thead>
- <tr>
- <td colspan="10" align="center"> 客户信息管理</td>
- </tr>
- </thead>
- <tbody>
- <tr align="center">
- <td>编号</td>
- <td>姓名</td>
- <td>代码</td>
- <td>生日</td>
- <td>家庭住址</td>
- <td>现居住地</td>
- <td>联系方式</td>
- <td>紧急联系方式</td>
- <td>注册日期</td>
- <td>操作</td>
- </tr>
- <c:forEach items="${clients}" var="c">
- <tr>
- <td> ${c.id} </td>
- <td> ${c.username} </td>
- <td> ${c.client_certificate_no} </td>
- <td> ${c.born_date} </td>
- <td> ${c.family_register_address} </td>
- <td> ${c.now_address} </td>
- <td> ${c.contact_mode} </td>
- <td> ${c.urgency_contact_mode} </td>
- <td> ${c.create_date} </td>
- <td><a href="${pageContext.request.contextPath}/clients/editClientIfo.action?id=${c.id}">查看</a></td>
- </tr>
- </c:forEach>
- </tbody>
- </table>
- </body>
4.Demo免积分下载
http://download.csdn.net/detail/lablenet/9396235
Spring MVC - 拦截器实现 和 用户登陆例子的更多相关文章
- spring mvc 拦截器的使用
Spring MVC 拦截器的使用 拦截器简介 Spring MVC 中的拦截器(Interceptor)类似于 Servler 中的过滤器(Filter).用于对处理器进行预处理和后处理.常用于日志 ...
- Spring Boot 2.X(九):Spring MVC - 拦截器(Interceptor)
拦截器 1.简介 Spring MVC 中的拦截器(Interceptor)类似于 Servlet 开发中的过滤器 Filter,它主要用于拦截用户请求并作相应的处理,它也是 AOP 编程思想的体现, ...
- 写的太细了!Spring MVC拦截器的应用,建议收藏再看!
Spring MVC拦截器 拦截器是Spring MVC中强大的控件,它可以在进入处理器之前做一些操作,或者在处理器完成后进行操作,甚至是在渲染视图后进行操作. 拦截器概述 对于任何优秀的MVC框架, ...
- Spring MVC拦截器浅析
Spring MVC拦截器 重点:Spring MVC的拦截器只会拦截控制器的请求,如果是jsp.js.image.html则会放行. 什么是拦截器 运行在服务器的程序,先于Servlet或JSP之前 ...
- SSM(spring mvc+spring+mybatis)学习路径——2-2、spring MVC拦截器
目录 2-2 Spring MVC拦截器 第一章 概述 第二章 Spring mvc拦截器的实现 2-1 拦截器的工作原理 2-2 拦截器的实现 2-3 拦截器的方法介绍 2-4 多个拦截器应用 2- ...
- 【Java Web开发学习】Spring MVC 拦截器HandlerInterceptor
[Java Web开发学习]Spring MVC 拦截器HandlerInterceptor 转载:https://www.cnblogs.com/yangchongxing/p/9324119.ht ...
- Spring MVC拦截器配置
Spring MVC拦截器配置 (1)自定义拦截器 package learnspringboot.xiao.other; import org.springframework.web.servlet ...
- 对于Spring MVC 拦截器的一些了解
Spring MVC 拦截器的执行顺序 应用场景 假设请求 localhost:8080/ 则要求直接重定向到 localhost:8080/login ; 定义拦截器顺序 permission lo ...
- Spring MVC拦截器+注解方式实现防止表单重复提交
原理:在新建页面中Session保存token随机码,当保存时验证,通过后删除,当再次点击保存时由于服务器端的Session中已经不存在了,所有无法验证通过. 注,如果是集群的方式,则需要将token ...
随机推荐
- UOJ 171 【WC2016】挑战NPC
一开始还真没想到是一般图匹配这种模型(毕竟才会的带花树) 把每一个盒子拆成3个,每一个可以放置进它的小球分别向这三个点连边,然后这三个点在连成一个三元环,最终答案就是小球数目-匹配数. 由于是一般图, ...
- 洛谷P2777 [AHOI2016初中组]自行车比赛
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- 遇到Io阻塞时会切换任务之【爬虫版】
#! /usr/bin/env python3 # -*- coding:utf- -*- from urllib import request import gevent,time from gev ...
- jsjl_for_ubuntu12.04
1. VC++代码: #include <stdio.h> #include <windows.h> #include <wchar.h> void MoveMou ...
- Qt5.3.2_CentOS6.4_单步调试环境__20160306【勿删,繁琐】
20160306 全程没有f/q ZC:使用的虚拟机环境是:博客园VMwareSkill 的 “CentOS6.4_x86_120g__20160306.rar” 需要调试器 gdb ,从“http: ...
- boosting方法
概述 Boosting基本思想: 通过改变训练数据的概率分布(训练数据的权值分布),学习多个弱分类器,并将它们线性组合,构成强分类器. Boosting算法要求基学习器能对特定的数据分布进行学习,这可 ...
- [Java学习] Java多态和动态绑定
在Java中,父类的变量可以引用父类的实例,也可以引用子类的实例. 请读者先看一段代码: 1. public class Demo { 2. public static void main(Strin ...
- Android之RecyclerView实现时光轴
做项目的过程中有个需求需要时光轴,于是网上找了部分资料 ,写了个案例,现在分享给大家. 如图: activity_main.xml <?xml version="1.0" e ...
- Html之a标签的使用
使用 <a> 标签的方式: <a href="http://www.baidu.com">用戶协议s</a><br> <a h ...
- 49 DOM(2)
一.value属性: input ,select 标签 ,textarea 标签中有value属性, 获取他们属性值的方法,先获取该元素ele,然后ele.value得到value值. <!DO ...