• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >Java > Spring MVC--拦截器实现和用户登陆例子

Spring MVC--拦截器实现和用户登陆例子

作者:long77 字体:[增加 减小] 来源:互联网 时间:2017-05-28

long77 通过本文主要向大家介绍了springmvc拦截器例子,springmvc拦截器,springmvc拦截器配置,springmvc拦截,springmvc拦截jsp等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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; 
 } 
} 
</div>

在拦截器中有三个方法 :

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> 
</div>

(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"; 
 } 
} 
</div>

3.2 controller 登出业务实现

@RequestMapping("/clientLoginOut") 
 public String clientLoginOut(HttpSession httpSession){ 
 httpSession.invalidate(); 
 return "forward:clientsList.action"; 
 } 
</div>

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; 
 } 
 } 
} 
</div>

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> 
</div>

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%>" rel="external nofollow" > 
 <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" rel="external nofollow" > 
 --> 
 </head> 
 <body> 
 <form action="${pageContext.request.contextPath }/clients/clientLogin.action" method="post"> 
 姓名:<input type="text" name="username"> <br><br> 
 密码: <input type="text" name="password">



 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • Spring MVC--拦截器实现和用户登陆例子

相关文章

  • 2017-05-28命令提示符编译java的方法(必看篇)
  • 2017-05-28Java指定保留小数位数的方法
  • 2017-05-28详解springboot整合mongodb
  • 2017-05-28MyBatis+MySQL 返回插入的主键ID的方法
  • 2017-05-28java 中InputStream,String,File之间的相互转化对比
  • 2017-05-28Java clone方法详解及简单实例
  • 2017-05-28详解java中通过post方式访问后台服务器
  • 2017-05-28Spring Boot 集成Dubbo框架实例
  • 2017-05-28spring boot使用thymeleaf跳转页面实例代码
  • 2017-05-28java统计汉字字数的方法示例

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • java基于dom4j包实现对XML解析的方法
    • spring cglib 与 jdk 动态代理
    • 微信开发准备第一步 Maven仓库管理新建WEB项目
    • JAVA Frame 窗体背景图片,首位相接滚动代码实例
    • Java多线程并发编程 并发三大要素
    • SpringBoot下的值注入(推荐)
    • java中FileOutputStream中文乱码问题解决办法
    • java抓取网页或文件中的邮箱号码
    • Java使用NioSocket手动实现HTTP服务器
    • Java 中Timer和TimerTask 定时器和定时任务使用的例子

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有