spring security 实现账号密码登陆
时间: 2023-07-07 17:31:13 浏览: 100
Spring Security实现验证码登录功能
Spring Security 是一个强大的安全框架,提供了很多安全措施,包括身份认证、授权、攻击防护等。
要实现账号密码登录,首先需要配置一个登录页面和接收登录请求的控制器。在 Spring Security 的配置文件中,可以使用 `formLogin()` 方法配置登录页面和登录请求的控制器。示例代码如下:
```java
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Autowired
private UserDetailsService userDetailsService;
@Override
protected void configure(HttpSecurity http) throws Exception {
http
.authorizeRequests()
.antMatchers("/login", "/css/**", "/js/**").permitAll()
.anyRequest().authenticated()
.and()
.formLogin()
.loginPage("/login")
.loginProcessingUrl("/login")
.defaultSuccessUrl("/home")
.failureUrl("/login?error")
.usernameParameter("username")
.passwordParameter("password")
.permitAll()
.and()
.logout()
.logoutUrl("/logout")
.logoutSuccessUrl("/login?logout")
.permitAll();
}
@Autowired
public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
auth.userDetailsService(userDetailsService);
}
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
}
```
上述代码中,`configure()` 方法中配置了登录页面、登录请求的控制器、登录成功后跳转的页面、登录失败后跳转的页面以及用户名和密码的参数名等信息。`configureGlobal()` 方法中配置了自定义的 `UserDetailsService`。`passwordEncoder()` 方法中配置了密码加密方式,本例使用了 BCrypt 加密方式。
在自定义的 `UserDetailsService` 实现中,需要根据用户名获取用户信息,包括用户名、密码和角色等信息。
```java
@Service
public class UserDetailsServiceImpl implements UserDetailsService {
@Autowired
private UserRepository userRepository;
@Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
User user = userRepository.findByUsername(username);
if (user == null) {
throw new UsernameNotFoundException("User not found");
}
return new org.springframework.security.core.userdetails.User(user.getUsername(), user.getPassword(),
getAuthorities(user));
}
private List<GrantedAuthority> getAuthorities(User user) {
List<GrantedAuthority> authorities = new ArrayList<>();
for (Role role : user.getRoles()) {
authorities.add(new SimpleGrantedAuthority(role.getName()));
}
return authorities;
}
}
```
上述代码中,`loadUserByUsername()` 方法根据用户名从 UserRepository 中获取用户信息,并返回一个 `UserDetails` 对象。`getAuthorities()` 方法根据用户的角色信息返回用户的权限列表。这里使用了 `SimpleGrantedAuthority` 类来表示权限。
这样,就可以使用 Spring Security 实现账号密码登录了。
阅读全文