1、加入spring security的支持包,
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
2、主要實現兩個接口,一個是UserDetails 用戶詳細信息,一個是UserDetailsService用戶信息服務
public class AuthorityUser implements UserDetails {
private NewUser user;
public AuthorityUser(NewUser newUser) {
this.user = newUser;
}
@Override
public Collection<? extends GrantedAuthority> getAuthorities() {
List<NewAuthority> newAuthorities = user.getNewAuthorities();
if(user == null || newAuthorities.size() <1){
return AuthorityUtils.commaSeparatedStringToAuthorityList("");
}
StringBuilder commaBuilder = new StringBuilder();
for(NewAuthority authority : newAuthorities){
commaBuilder.append(authority.getName()).append(",");
}
String authorities = commaBuilder.substring(0,commaBuilder.length()-1);
return AuthorityUtils.commaSeparatedStringToAuthorityList(authorities);
}
@Override
public String getPassword() {
return user.getPassword();
}
@Override
public String getUsername() {
return user.getUsername();
}
@Override
public boolean isAccountNonExpired() {
return true;
}
@Override
public boolean isAccountNonLocked() {
return true;
}
@Override
public boolean isCredentialsNonExpired() {
return true;
}
@Override
public boolean isEnabled() {
return user.getEnable().equals(1)?true:false;
}
}
public class SpringDataUserDetailsService implements UserDetailsService {
@Autowired
NewUserMapper newUserMapper;
@Override
public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
NewUser user = newUserMapper.findByUsername(username);
if (user == null) {
throw new UsernameNotFoundException("username:" + username + " not found");
}
return new AuthorityUser(user);
}
}
3、在繼承WebSecurityConfigurerAdapter 子類中添加資源攔截規則和 用戶權限規則
@EnableWebSecurity
public class MySecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
//自定義權限規則
http.authorizeRequests().antMatchers("/").permitAll()
.antMatchers("/level1/**").hasAuthority("VIP1")
.antMatchers("/level2/**").hasAuthority("VIP2")
.antMatchers("/level3/**").hasAuthority("VIP3");
//開啟自動配置的登陸功能
http.formLogin().usernameParameter("user").passwordParameter("pwd").loginPage("/userlogin");
//開啟自動配置注銷
http.logout().logoutSuccessUrl("/");//注銷成功來到首頁
http.rememberMe().rememberMeParameter("remenber");//開啟記住我功能
}
//定義認證規則
@Override
protected void configure(AuthenticationManagerBuilder auth) throws Exception {
//設置自定義UserDetailService,用以從數據庫加載用戶信息
auth.userDetailsService(springDataUserDetailsService())
//設置密碼加密
.passwordEncoder(new MyPasswordEncoder());
}
@Bean
public SpringDataUserDetailsService springDataUserDetailsService() {
return new SpringDataUserDetailsService();
}
