springmvc拦截器登录验证示例
发布时间 - 2026-01-10 23:20:33 点击率:次一开始,学了拦截器与过滤器,咋一看两者有点像,实际上两者有很大的不同。就用拦截器和过滤器分别做了登录验证试验,这次先说拦截器。下面是自己实践的一个实例:

在spring-mvc.xml中配置拦截器:
<mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/user/*"/> <!-- 定义在mvc:interceptor下面的表示是对特定的请求才进行拦截的 --> <bean class="com.wyb.interceptor.LoginInterceptor"/> </mvc:interceptor> </mvc:interceptors>
如上所示,这里配置了LoginIntercepter,为了简单起见,该过滤器只拦截了URL为"/user/*"的请求。
要拦截的请求对应控制器如下:
import java.util.ArrayList;
import java.util.List;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;
import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.wyb.domain.User;
import com.wyb.service.IUserService;
import com.wyb.service.impl.UserServiceImpl;
@Controller
@RequestMapping("/user")
public class UserController {
private static final Logger LOG=Logger.getLogger(UserController.class);
@Autowired
private IUserService userService;
@RequestMapping("/showAllUser")
public String showAllUser(Model m){
List<User> userlist=new ArrayList<User>();
userlist=userService.findAllUser();
for(User user :userlist){
System.out.println(user.getUserName());
}
return "/jsp/showAllUser";
}
}
这里的showAllUser()方法是为了输出所有的用户,为了表明执行了方法,将所有用户在后台打印,URL为:http://localhost:8080/TestSSM/user/showAllUser,可见该URL肯定会被LoginIntercepter拦截。
测试页面showAllUser.jsp如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>show All User</title> </head> <body> this is showAllUser Page!!! </body> </html>
LoginIntercepter如下:
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;
import com.wyb.domain.User;
public class LoginInterceptor implements HandlerInterceptor{
@Override
public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
System.out.println("this is afterCompletion of LoginInterceptor");
}
@Override
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
throws Exception {
System.out.println("this is postHandle of LoginInterceptor");
}
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
// TODO Auto-generated method stub
System.out.println("this is preHandle of LoginInterceptor");
HttpSession session=request.getSession();
User user=(User)session.getAttribute("user");
if(user==null){
System.out.println("no user in LoginInterceptor!!!");
request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
}
//返回true代表继续往下执行
return true;
}
}
这里我犯了一个错误,聪明的小伙伴也许已经看出来了,如果按照上面的代码,当我们访问:http://localhost:8080/TestSSM/user/showAllUser结果如下:
咋一看,成功拦截了,输入用户名信息,正常跳转到主页,再次进入http://localhost:8080/TestSSM/user/showAllUser如下:
页面正常输出,已经记录了session,不会被再次拦截,看似成功了,可是看看后台输出:
有没有发现,我们执行了两次showAllUser()方法,可见第一次访问虽然被拦截器拦截了下来进入登录页面,但后台已经悄悄执行了showAllUser()。为什么呢?我们回头再看看LoginIntercepter.java,尤其是preHandle()方法:
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
// TODO Auto-generated method stub
System.out.println("this is preHandle of LoginInterceptor");
HttpSession session=request.getSession();
User user=(User)session.getAttribute("user");
if(user==null){
System.out.println("no user in LoginInterceptor!!!");
request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
}
//返回true代表继续往下执行
return true;
}
在判断user为空后,虽然执行了页面跳转,但是程序还是会继续执行,最后返回true,返回true意味着,被拦截的业务逻辑可以继续往下执行,因此,虽然表面上被拦截了,但从本质上来说并没有拦截到。因此需要修改如下:
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
// TODO Auto-generated method stub
System.out.println("this is preHandle of LoginInterceptor");
HttpSession session=request.getSession();
User user=(User)session.getAttribute("user");
if(user==null){
System.out.println("no user in LoginInterceptor!!!");
request.getRequestDispatcher("/WEB-INF/jsp/login.jsp").forward(request, response);
//本次访问被拦截,业务逻辑不继续执行
return false;
}
//返回true代表继续往下执行
return true;
}
user为空,跳转后,返回false,就不会执行被拦截的业务逻辑了,修改后后台输出如下:
现在后台正常输出,且session保存了user信息后,才能执行showAllUser()方法,大功告成!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# springmvc
# 登录拦截器
# 拦截器
# springmvc登录拦截
# SpringMVC自定义拦截器登录检测功能的实现代码
# SpringMVC 如何使用注解完成登录拦截
# SpringMVC配置拦截器实现登录控制的方法
# SpringMVC拦截器——实现登录验证拦截器的示例代码
# SpringMVC拦截器实现登录认证
# 基于SpringMVC实现网页登录拦截
# 往下
# 跳转
# 为空
# 来了
# 尤其是
# 两次
# 大功告成
# 什么呢
# 当我们
# 所示
# 就用
# 表面上
# 输入用户名
# 学了
# 有点像
# 再看看
# 先说
# 本质上
# 大家多多
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Win11怎么关闭专注助手 Win11关闭免打扰模式设置【操作】
Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理
Laravel怎么配置自定义表前缀_Laravel数据库迁移与Eloquent表名映射【步骤】
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
如何快速搭建高效WAP手机网站?
SQL查询语句优化的实用方法总结
Laravel的HTTP客户端怎么用_Laravel HTTP Client发起API请求教程
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
打开php文件提示内存不足_怎么调整php内存限制【解决方案】
如何在Windows 2008云服务器安全搭建网站?
如何快速搭建高效香港服务器网站?
如何选择PHP开源工具快速搭建网站?
如何续费美橙建站之星域名及服务?
如何实现javascript表单验证_正则表达式有哪些实用技巧
Laravel如何创建自定义中间件?(Middleware代码示例)
如何确认建站备案号应放置的具体位置?
韩国服务器如何优化跨境访问实现高效连接?
Python企业级消息系统教程_KafkaRabbitMQ高并发应用
html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】
网站建设要注意的标准 促进网站用户好感度!
Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】
Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程
php在windows下怎么调试_phpwindows环境调试操作说明【操作】
成都品牌网站制作公司,成都营业执照年报网上怎么办理?
儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?
利用JavaScript实现拖拽改变元素大小
制作电商网页,电商供应链怎么做?
Laravel怎么使用Session存储数据_Laravel会话管理与自定义驱动配置【详解】
网站制作壁纸教程视频,电脑壁纸网站?
如何快速建站并高效导出源代码?
如何获取PHP WAP自助建站系统源码?
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤
Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
javascript中对象的定义、使用以及对象和原型链操作小结
微信小程序 input输入框控件详解及实例(多种示例)
使用Dockerfile构建java web环境
Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】
微信小程序 canvas开发实例及注意事项
如何在建站之星网店版论坛获取技术支持?
Laravel Seeder填充数据教程_Laravel模型工厂Factory使用
bing浏览器学术搜索入口_bing学术文献检索地址
Laravel如何记录自定义日志?(Log频道配置)
Python自然语言搜索引擎项目教程_倒排索引查询优化案例
如何用JavaScript实现文本编辑器_光标和选区怎么处理
Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复
Laravel如何与Inertia.js和Vue/React构建现代单页应用

