扫码阅读
手机扫码阅读
Sping Security-3-动态认证用户信息
135 2024-07-19
我们非常重视原创文章,为尊重知识产权并避免潜在的版权问题,我们在此提供文章的摘要供您初步了解。如果您想要查阅更为详尽的内容,访问作者的公众号页面获取完整文章。
文章来源:
springboot葵花宝典
扫码关注公众号
概述
本文介绍了如何在Spring Security中实现动态认证用户信息,即从数据库中获取用户信息进行身份认证,使用UserDetailsService接口和其实现类JdbcUserDetailsManager。
项目准备
添加依赖
项目使用MySQL数据库和MyBatis-Plus,因此需要添加相应的mysql-connector-java和mybatis-plus-boot-starter依赖。
添加数据库配置
在application.yml中配置数据库连接信息,包括URL、用户名和密码。
创建user和权限表
创建用户(sys_user)和权限(sys_authorities)表,并插入示例数据。
实体类
定义sys_user和sys_authorities两个实体类,对应数据库中的表。
实现两个实体类的Mapper
使用MyBatis-Plus简化Mapper的实现。
添加@MapperScan注解
在Spring Boot主程序类上添加@MapperScan注解,指定Mapper接口所在包。
UserDetailsService的实现
重构configure(AuthenticationManagerBuilder auth)方法
实现自定义UserDetailsService接口的CustomUserDetailsService类,重写loadUserByUsername方法,从数据库获取用户信息。然后在配置类中重构configure方法,使用自定义的UserDetailsService来认证用户。
测试
启动项目并访问登录页面,使用提供的账号和密码进行测试。
文章结尾鼓励读者关注、点赞、收藏以支持作者,并邀请分享本文。
想要了解更多内容?
文章来源:
springboot葵花宝典
扫码关注公众号
springboot葵花宝典的其他文章
什么Mysql索引失效,一文教你读懂Mysql索引使用规则和失效原因
一文教你读懂Mysql索引使用规则和失效原因
SpringSecurity-9-实现通过手机短信进行认证功能
SpringSecurity-9-实现通过手机短信进行认证功能
SpringBoot之实现RabbitMQ消息队列简单发送接收消息
今天接着简单介绍了SpringBoot实现RabbitMQ的消息接收和发送
深入Redis内幕:通信协议、内存回收与淘汰策略
深入Redis内幕:通信协议、内存回收与淘汰策略
从源头到终点:解密 RabbitMQ 消息丢失的神奇解决方案!
RabbitMQ 是一个强大的消息队列系统,但在一些情况下,可能会发生消息丢失的问题。为了确保消息的可靠性传输,本文介绍采取什么措施来解决消息丢失的问题
加入社区微信群
与行业大咖零距离交流学习
软件研发质量管理体系建设
白皮书上线