当前位置: 首页 > 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.dtcms.com/a/267871.html

相关文章:

  • Jiraph​ 简介
  • React 各颜色转换方法、颜色值换算工具HEX、RGB/RGBA、HSL/HSLA、HSV、CMYK
  • AcWing--873.欧拉函数
  • ARMv8 创建1、2、3级页表代码与注释
  • 【C++基础】内存管理四重奏:malloc/free vs new/delete - 面试高频考点与真题解析
  • Windows 11 Enterprise LTSC 转 IoT
  • C++ i386/AMD64平台汇编指令对齐长度获取实现
  • LangChain:构建一个Agent(入门篇四)
  • [leetcode] C++ 并查集模板
  • 【机器学习笔记 Ⅱ】1 神经网络
  • 云原生 Serverless 架构下的智能弹性伸缩与成本优化实践
  • 基于HTML与Java的简易在线会议系统实现
  • Javaweb - 10.5 HttpServletRequest 和 HttpServletResponse
  • Flink ClickHouse 连接器维表源码深度解析
  • 【Note】《Kafka: The Definitive Guide》第四章:Kafka 消费者全面解析:如何从 Kafka 高效读取消息
  • 深入理解Kafka幂等性:原理、边界与最佳实践
  • Neo4j 综合练习作业
  • Android 应用开发 | 一种限制拷贝速率解决因 IO 过高导致系统卡顿的方法
  • java ThreadLocal源码分析
  • 深度学习6(多分类+交叉熵损失原理+手写数字识别案例TensorFlow)
  • 高效处理大体积Excel文件的Java技术方案解析
  • 安卓之service
  • QT 菜单栏设计使用方法
  • 基于AndServer的RPC架构:Android原生SO文件远程调用实战指南
  • Python 机器学习核心入门与实战进阶 Day 4 - 支持向量机(SVM)原理与分类实战
  • 深度学习图像分类数据集—蘑菇识别分类
  • plantuml用法总结
  • Java设计模式之行为型模式(策略模式)介绍与说明
  • 利用低空无人机影像进行树种实例分割
  • 深入解析Vue中v-model的双向绑定实现原理