基于spring boot学生宿舍管理系统登录功能之不同角色判断验证

时间: 2023-07-29 10:10:33 浏览: 63
在学生宿舍管理系统中,不同的用户角色可能有不同的权限和访问限制,因此需要在登录时对用户进行角色判断验证。下面是基于Spring Boot的实现方式: 1. 创建一个User实体类,用于存储用户信息,包括用户名、密码和角色等字段。 2. 创建一个UserService类,用于实现用户登录验证功能。该类需要依赖一个UserRepository接口,用于从数据库中获取用户信息。 3. 在Spring Security配置类中,使用AuthenticationProvider接口实现身份验证逻辑。在该接口的实现类中,通过调用UserService类的方法来验证用户的身份和角色。 4. 在登录页面中,根据用户输入的用户名和密码,调用UserService类的登录验证方法,验证用户身份和角色是否正确。如果验证通过,则将用户信息存储在Session中,并跳转到对应角色的主页面;否则返回登录页面并提示错误信息。 示例代码: User实体类: ``` @Entity @Table(name = "user") public class User implements Serializable { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(nullable = false, unique = true) private String username; @Column(nullable = false) private String password; @Column(nullable = false) private String role; // 省略getter和setter方法 } ``` UserRepository接口: ``` @Repository public interface UserRepository extends JpaRepository<User, Long> { User findByUsername(String username); } ``` UserService类: ``` @Service public class UserService { @Autowired private UserRepository userRepository; public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException { User user = userRepository.findByUsername(username); if (user == null) { throw new UsernameNotFoundException("用户不存在"); } List<GrantedAuthority> authorities = new ArrayList<>(); authorities.add(new SimpleGrantedAuthority(user.getRole())); return new org.springframework.security.core.userdetails.User(user.getUsername(), user.getPassword(), authorities); } public User login(String username, String password) { User user = userRepository.findByUsername(username); if (user == null) { throw new RuntimeException("用户不存在"); } if (!user.getPassword().equals(password)) { throw new RuntimeException("密码不正确"); } return user; } } ``` Spring Security配置类: ``` @Configuration @EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { @Autowired private UserService userService; @Override protected void configure(AuthenticationManagerBuilder auth) throws Exception { auth.authenticationProvider(new AuthenticationProvider() { @Override public Authentication authenticate(Authentication authentication) throws AuthenticationException { String username = authentication.getName(); String password = authentication.getCredentials().toString(); User user = userService.login(username, password); List<GrantedAuthority> authorities = new ArrayList<>(); authorities.add(new SimpleGrantedAuthority(user.getRole())); return new UsernamePasswordAuthenticationToken(user.getUsername(), user.getPassword(), authorities); } @Override public boolean supports(Class<?> aClass) { return true; } }); } @Override protected void configure(HttpSecurity http) throws Exception { http.authorizeRequests() .antMatchers("/admin/**").hasRole("admin") .antMatchers("/user/**").hasRole("user") .and() .formLogin() .loginPage("/login") .defaultSuccessUrl("/index") .permitAll() .and() .logout() .permitAll(); } } ``` 在登录页面中,根据用户输入的用户名和密码,调用UserService类的login方法进行验证: ``` @Controller public class LoginController { @Autowired private UserService userService; @GetMapping("/login") public String login() { return "login"; } @PostMapping("/login") public String doLogin(@RequestParam String username, @RequestParam String password, HttpSession session) { User user = userService.login(username, password); session.setAttribute("user", user); if (user.getRole().equals("admin")) { return "redirect:/admin/index"; } else { return "redirect:/user/index"; } } } ``` 以上是一个基于Spring Boot实现的学生宿舍管理系统登录功能之不同角色判断验证的示例代码,仅供参考。

相关推荐

最新推荐

recommend-type

基于Spring Boot的校园食堂订餐系统的设计与实现.doc

本文在考虑到以上的问题的基础上,利用大学期间中所学到的的专业知识,独立开发一个基于Spring Boot和vue.js的校园食堂订餐系统。论文首先进行了系统功能的总体设计,使本系统具有以下主要功能:一是具有手机端让...
recommend-type

基于spring-boot和docker-java实现对docker容器的动态管理和监控功能[附完整源码下载]

Docker 是一个开源的应用容器引擎,和传统的虚拟机技术相比,Docker 容器性能开销极低,因此也广受开发者...这篇文章主要介绍了基于spring-boot和docker-java实现对docker容器的动态管理和监控 ,需要的朋友可以参考下
recommend-type

若依通用权限管理系统接口文档,是一个 Java EE 企业级快速开发平台,基于经典技术组合(Spring Boot、Spring

若依是一个 Java EE 企业级快速开发平台,基于经典技术组合(Spring Boot、Spring Security、MyBatis、Jwt、Vue),内置模块如:部门管理、角色用户、菜单及按钮授权、数据权限、系统参数、日志管理、代码生成等。...
recommend-type

基于SpringBoot的学生作业管理系统的配置

基于SpringBoot的学生作业管理系统的配置,https://download.csdn.net/download/qq_41593124/85228752?spm=1001.2014.3001.5503
recommend-type

基于Android和Spring Boot的心理互助社区系统设计与实现.docx

本文设计并实现了一个基于Android和Spring Boot的网络社区系统,主题是心理互助,开发目的是为了让出现轻度心理问题的人们有一个交流互动的平台,通过线上交流、平等互助地方式改善每一个人的心理状态,成为一个身心...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

SPDK_NVMF_DISCOVERY_NQN是什么 有什么作用

SPDK_NVMF_DISCOVERY_NQN 是 SPDK (Storage Performance Development Kit) 中用于查询 NVMf (Non-Volatile Memory express over Fabrics) 存储设备名称的协议。NVMf 是一种基于网络的存储协议,可用于连接远程非易失性内存存储器。 SPDK_NVMF_DISCOVERY_NQN 的作用是让存储应用程序能够通过 SPDK 查询 NVMf 存储设备的名称,以便能够访问这些存储设备。通过查询 NVMf 存储设备名称,存储应用程序可以获取必要的信息,例如存储设备的IP地址、端口号、名称等,以便能
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。