当前位置: 首页 > news >正文

实现Spring MVC登录验证与拦截器保护:从原理到实战

本文将基于提供的代码,详细解析如何实现Spring MVC的登录验证和拦截器保护机制。通过前端页面、控制器、拦截器的协同工作,确保系统资源的安全访问。

1. 核心组件说明
文件功能说明
LoginController.java处理登录请求、跳转页面的控制器
lanjieqi.java拦截器:验证用户登录状态(类名建议改为AuthInterceptor更规范)
User.java用户实体类(存储用户名密码)
Response.java统一响应对象(返回状态码和消息)
springmvc.xmlSpring MVC核心配置(扫描包、视图解析器、拦截器注册)
login.html登录页面(AJAX提交请求)
index.html主页(登录成功后访问)

2. 登录验证流程
(1) 前端请求处理 (login.html)
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>登录页面</title><script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
</head>
<body>
用户名:<input type="text" id="name" placeholder="请输入用户名" /> <br/>
密码:<input type="text" id="password" placeholder="请输入密码" /> <br/>
<input type="button" value="登录" onclick="login()">
</body>
<script>function login(){var name = $("#name").val();var password = $("#password").val();$.ajax({url:"/SpringMVC/login",type:"get",data:{name:name,password:password}, success:function(data){console.log(data)if(data.code == 200){window.location.href = "/SpringMVC/toIndex";}else{alert(data.message);}}})}
</script>
</html>
(2) 后端验证逻辑 (LoginController.java)
package com.qcby.controller;import com.qcby.entity.Response;
import com.qcby.entity.User;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;@Controller
public class LoginController {@RequestMapping("/toLogin")public String toLogin(){return "login";}@RequestMapping("/toIndex")public String index(){return "index";}@RequestMapping("/login")@ResponseBodypublic Response login(User user, HttpServletRequest request) {if(user.getName().equals("admin") && user.getPassword().equals("123456")){//设置sessionHttpSession session = request.getSession();session.setAttribute("loginUser",user);return new Response("200","登录成功");}else {return new Response("500","登录失败");}}}
3. 拦截器保护机制
(1) 拦截器核心逻辑 (lanjieqi.java)

如何不理解拦截器请看Spring MVC拦截器深度解析:掌控请求生命周期的艺术-CSDN博客

package com.qcby.interceptor;import org.springframework.web.servlet.HandlerInterceptor;import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.xml.ws.handler.Handler;
import java.security.PublicKey;public class lanjieqi implements HandlerInterceptor {@Overridepublic boolean preHandle(HttpServletRequest request, HttpServletResponse response,Object handler) throws Exception {//获取当前访问的urlString url = request.getRequestURI(); //http://localhost:8080/SpringMVC/login  登录时的请求if(!url.contains("login") && !url.contains("toLogin")){  //非登录时的请求if(request.getSession().getAttribute("loginUser")!=null){  //说明已经登录过return true;}else {//要求其进行登录response.sendRedirect("/SpringMVC/toLogin"); //重定向到登录页面}}else {  //登录时的请求return true; //放行}return false;}
}
(2) 拦截器配置 (springmvc.xml)
<mvc:interceptors><mvc:interceptor><mvc:mapping path="/toIndex"/> <!-- 拦截主页请求 --><bean class="com.qcby.interceptor.lanjieqi"/> </mvc:interceptor>
</mvc:interceptors>
4. 完整交互流程
  1. 用户访问主页
    http://localhost:8080/toIndex → 拦截器检测未登录 → 重定向到/toLogin

  2. 渲染登录页
    控制器返回login.html → 用户输入凭据 → AJAX提交到/login

  3. 服务端验证

    • 成功:存储Session → 返回{code:200} → 前端跳转主页

    • 失败:返回{code:500} → 前端弹窗提示

  4. 访问受保护资源
    再次访问/toIndex → 拦截器检测Session存在 → 放行并展示index.html

5. 总结

通过本文实现的登录系统,我们掌握了:

  • 使用Session管理用户登录状态

  • 拦截器实现路由级别的权限控制

  • AJAX与后端RESTful风格的交互

  • Spring MVC的配置与组件协同

关键设计思想

“前端轻量化请求,后端无状态验证,拦截器统一守门”

完整代码已在上文提供,建议结合实际需求扩展密码加密、多端会话管理等功能以提升安全性。

http://www.lryc.cn/news/581645.html

相关文章:

  • 【机器学习深度学习】 如何解决“宏平均偏低 / 小类识别差”的问题?
  • HRDNet: High-resolution Detection Network for Small Objects论文阅读
  • mac中创建 .command 文件,执行node服务
  • Omi录屏专家 Screen Recorder by Omi 屏幕录制Mac
  • 【Linux】基础开发工具(1)
  • 开发项目时遇到的横向越权、行锁表锁与事务的关联与区别、超卖问题
  • Java学习——Lombok
  • Anaconda 常用命令
  • 【Elasticsearch】自定义评分检索
  • 【卫星语音】基于神经网络的低码率语音编解码(ULBC)方案架构分析:以SoundStream为例
  • Maven引入第三方JAR包实战指南
  • Day06- (使用asyncio进行异步编程:事件循环和协程)
  • 群晖 DS3617xs DSM 6.1.7 解决 PhotoStation 安装失败问题 PHP7.0
  • 数据结构---B+树
  • Modbus 与 BACnet 协议互操作:工业协议转换方案(二)
  • 深入理解 classnames:React 动态类名管理的最佳实践
  • 【系统分析师】2023年真题:论文及解题思路
  • 【机器学习笔记Ⅰ】7 向量化
  • 【IOS】XCode创建firstapp并运行(成为IOS开发者)
  • Tuning Language Models by Proxy
  • CentOS-6与CentOS-7的网络配置IP设置方式对比 笔记250706
  • 【Vibe Coding 实战】我如何用 AI 把一张草图变成了能跑的应用
  • 黑马点评系列问题之基础篇16jedis redis依赖引入后仍然还是报错
  • Docker 容器编排原理与使用详解
  • 国内Ubuntu访问不了github等外网
  • 牛客周赛Round 99(Go语言)
  • 【前端工程化】前端工作中的业务规范有哪些
  • 4.2 如何训练⼀个 LLM
  • Redis主从切换踩坑记:当Redisson遇上分布式锁的“死亡连接“
  • 鼓式制动器的设计+(说明书和CAD【6张】 - 副本➕降重