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

创建首个 Spring Boot 登录项目

📌 摘要

在 Java Web 开发中,登录功能是最基础也是最重要的模块之一。本文将手把手带你使用 IntelliJ IDEA 和 Maven 构建一个基于 Spring Boot 的简单登录系统,涵盖:

  • 使用 IDEA 创建 Spring Boot 项目
  • 配置 Maven 依赖(Spring Web、Spring Security、Thymeleaf)
  • 数据库连接与用户验证逻辑
  • 登录页面设计与控制器实现
  • 登出功能和权限控制
  • 常见问题解析与最佳实践

适合刚入门 Spring Boot 的新手开发者,帮助你快速搭建一个完整的登录系统原型。


🎯 一、开发环境准备

工具版本要求
JDK1.8 或以上
IntelliJ IDEA社区版 / 旗舰版
Maven3.x 及以上
MySQL5.7 或 8.0
Spring Boot推荐 2.6.x ~ 3.x

🧱 二、创建 Spring Boot 项目(使用 IDEA)

步骤 1:打开 IDEA,选择“New Project”

在这里插入图片描述

步骤 2:选择 “Spring Initializr”,填写项目信息

  • Group:com.example
  • Artifact:login-demo
  • Language:Java
  • Packaging:Jar
  • Java Version:17(或其他版本)
    在这里插入图片描述

步骤 3:选择依赖项

勾选以下依赖:

  • Spring Web
  • Spring Security
  • Thymeleaf(可选,用于前端模板)
  • Spring Data JPA(可选,用于数据库操作)
  • MySQL Driver(可选,用于连接数据库)
    在这里插入图片描述
    点击 “Create” 完成创建。

📦 三、项目结构说明

src/
├── main/
│   ├── java/
│   │   └── com.example.logindemo/
│   │       ├── controller/LoginController.java
│   │       └── LoginDemoApplication.java
│   ├── resources/
│   │   ├── static/
│   │   │   └── css/, js/, images/
│   │   ├── templates/
│   │   │   └── login.html, home.html
│   │   └── application.yml

![](https://i-blog.csdnimg.cn/direct/ba9b6b4dac23448e9b4a184c4f3c7454.png


🔧 四、配置 application.yml 文件

spring:datasource:url: jdbc:mysql://localhost:3306/login_db?useSSL=false&serverTimezone=UTCusername: rootpassword: yourpassworddriver-class-name: com.mysql.cj.jdbc.Driverthymeleaf:cache: falsesuffix: .htmlprefix: classpath:/templates/encoding: UTF-8content-type: text/html

💻 五、创建数据库与用户表

CREATE DATABASE login_db;USE login_db;CREATE TABLE users (id INT PRIMARY KEY AUTO_INCREMENT,username VARCHAR(50) NOT NULL UNIQUE,password VARCHAR(100) NOT NULL
);INSERT INTO users (username, password) VALUES ('admin', '$2a$10$X60FfSIxIgOcZtIXTzKqCeVWwGvQkHlR8eYzE2LmZsS');

注意:密码使用 BCrypt 加密,如上例中的 $2a$10$..."123456" 加密后的结果。


🔐 六、配置 Spring Security 安全框架

创建配置类 SecurityConfig.java

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;
import org.springframework.security.web.SecurityFilterChain;@Configuration
@EnableWebSecurity
public class SecurityConfig {@Beanpublic PasswordEncoder passwordEncoder() {return new BCryptPasswordEncoder();}@Beanpublic SecurityFilterChain filterChain(HttpSecurity http) throws Exception {http.authorizeRequests().requestMatchers("/", "/login").permitAll().anyRequest().authenticated().and().formLogin().loginPage("/login").defaultSuccessUrl("/home").failureUrl("/login?error=true").permitAll().and().logout().logoutSuccessUrl("/").permitAll();return http.build();}
}

🖼️ 七、创建登录页面 login.html(放在 templates 目录下)

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head><title>登录</title>
</head>
<body>
<h2>登录页面</h2><form th:action="@{/login}" method="post"><div th:if="${param.error}"><p style="color:red;">用户名或密码错误</p></div><label>用户名:</label><input type="text" name="username"/><br/><label>密码:</label><input type="password" name="password"/><br/><button type="submit">登录</button>
</form>
</body>
</html>

🏠 八、创建首页 home.html(登录成功后跳转)

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head><title>首页</title>
</head>
<body>
<h2>欢迎来到主页!</h2>
<a href="/logout">退出登录</a>
</body>
</html>

🧩 九、编写控制器 LoginController.java

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;@Controller
public class LoginController {@GetMapping("/")public String index() {return "login";}@GetMapping("/login")public String login() {return "login";}@GetMapping("/home")public String home() {return "home";}
}

✅ 十、测试运行项目

  1. 启动 Spring Boot 应用
  2. 浏览器访问:http://localhost:8080
  3. 输入用户名 admin 和密码 123456
  4. 成功登录后跳转至 /home
  5. 点击退出,回到登录页

🧪 十一、常见问题与解决方案

Q1: 登录失败,提示 Bad credentials?

  • 检查数据库密码是否是 BCrypt 加密格式
  • 检查用户名是否正确匹配数据库字段

Q2: 页面无法访问?

  • 检查 Controller 路径映射是否正确
  • 查看启动日志是否有报错

Q3: 登录成功后无法跳转?

  • 检查 defaultSuccessUrl() 是否设置正确
  • 确保没有拦截 /home 路径

Q4: 如何自定义用户加载逻辑?

  • 实现 UserDetailsService 接口,重写 loadUserByUsername() 方法


📚 十二、参考资料

  • Spring Boot 官方文档
  • Thymeleaf 官方文档
  • Spring Security 中文社区

  • 如果你在学习过程中遇到任何问题,欢迎在评论区留言交流!
  • 👍 如果你觉得这篇文章对你有帮助,别忘了点赞、收藏、转发哦!
http://www.lryc.cn/news/574528.html

相关文章:

  • DD3118S:USB3.0+Type-c双头TF/SD二合一高速0TG多功能手机读卡器ic
  • 76、单元测试-参数化测试
  • 做上门私厨/上门做饭App小程序,到底是定制开发,还是选成品系统?
  • 随机森林详解:原理、优势与应用实践
  • 【空间数据分析】全局莫兰指数(Global Moran’s I)
  • 《C++》命名空间简述
  • 项目练习:使用itextpdf制作pdf报表
  • 电商场景BI解决方案:用观远BI捕获电商大促增长先机
  • (3)ROS2:6-dof前馈+PD / 阻抗控制器
  • 常见网络知识,宽带、路由器
  • UAVAI-YOLO:无人机航拍图像的小目标检测模型
  • NLP基础1_word-embedding
  • 桥头守望者
  • iostat中的util原理
  • OpenCV CUDA模块设备层-----检查 CUDA 错误并输出调试信息内联函数checkCudaError()
  • 【STM32】JTAG / SWD 调试原理简析
  • IN子查询与JOIN的区别理解
  • 数据赋能(319)——安全与合规——数据安全可控
  • 烟花爆竹生产企业库房存储安全风险预警系统
  • 前端如何让用户回到上次阅读的位置?
  • 医学数据分析实战:冠心病发病因素可视化
  • vue3+echarts实现tab切换多个图表
  • 微信小程序节点相关总结
  • 服务器常见问题以及解决方案
  • 学习threejs,使用kokomi、gsap实现图片环效果
  • 【AI落地应用实战】Chaterm:重新定义终端操作的AI智能工具
  • mapbox基础,导出地图
  • 打表法从原理到实战详解
  • RabbitMQ + JMeter 深度集成指南:中间件性能优化全流程解析!
  • uniapp/Vue/微信小程序瀑布流,小红书瀑布流,豆瓣瀑布流,淘宝瀑布流布局