一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Spring Security基于數據庫實現認證過程解析

Spring Security基于數據庫實現認證過程解析

2020-08-17 12:14柒丶月 Java教程

這篇文章主要介紹了Spring Security基于數據庫實現認證過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

創建數據庫

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
SET FOREIGN_KEY_CHECKS=0;
    -- ----------------------------
    -- Table structure for role
    -- ----------------------------
    DROP TABLE IF EXISTS `role`;
    CREATE TABLE `role` (
    `id` int(11) NOT NULL AUTO_INCREMENT,
    `name` varchar(32) DEFAULT NULL,
    `nameZh` varchar(32) DEFAULT NULL,
    PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
    -- ----------------------------
    -- Records of role
    -- ----------------------------
    INSERT INTO `role` VALUES ('1', 'dba', '數據庫管理員');
    INSERT INTO `role` VALUES ('2', 'admin', '系統管理員');
    INSERT INTO `role` VALUES ('3', 'user', '用戶');
    -- ----------------------------
    -- Table structure for user
    -- ----------------------------
    DROP TABLE IF EXISTS `user`;
    CREATE TABLE `user` (
    `id` int(11) NOT NULL AUTO_INCREMENT,
    `username` varchar(32) DEFAULT NULL,
    `password` varchar(255) DEFAULT NULL,
    `enabled` tinyint(1) DEFAULT NULL,
    `locked` tinyint(1) DEFAULT NULL,
    PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
    -- ----------------------------
    -- Records of user
    -- ----------------------------
    INSERT INTO `user` VALUES ('1', 'root', '$2a$10$RMuFXGQ5AtH4wOvkUqyvuecpqUSeoxZYqilXzbz50dceRsga.WYiq', '1', '0');
    INSERT INTO `user` VALUES ('2', 'admin', '$2a$10$RMuFXGQ5AtH4wOvkUqyvuecpqUSeoxZYqilXzbz50dceRsga.WYiq', '1', '0');
    INSERT INTO `user` VALUES ('3', 'sang', '$2a$10$RMuFXGQ5AtH4wOvkUqyvuecpqUSeoxZYqilXzbz50dceRsga.WYiq', '1', '0');
    -- ----------------------------
    -- Table structure for user_role
    -- ----------------------------
    DROP TABLE IF EXISTS `user_role`;
    CREATE TABLE `user_role` (
    `id` int(11) NOT NULL AUTO_INCREMENT,
    `uid` int(11) DEFAULT NULL,
    `rid` int(11) DEFAULT NULL,
    PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;
    -- ----------------------------
    -- Records of user_role
    -- ----------------------------
    INSERT INTO `user_role` VALUES ('1', '1', '1');
    INSERT INTO `user_role` VALUES ('2', '1', '2');
    INSERT INTO `user_role` VALUES ('3', '2', '2');
    INSERT INTO `user_role` VALUES ('4', '3', '3');
    SET FOREIGN_KEY_CHECKS=1;

導入依賴

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>org.mybatis.spring.boot</groupId>
  <artifactId>mybatis-spring-boot-starter</artifactId>
  <version>2.1.3</version>
</dependency>
 
<dependency>
  <groupId>mysql</groupId>
  <artifactId>mysql-connector-java</artifactId>
  <scope>runtime</scope>
  <version>5.1.46</version>
</dependency>
<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>druid-spring-boot-starter</artifactId>
  <version>1.1.22</version>
</dependency>

spring.datasource.url=jdbc:mysql://127.0.0.1:3306/javaboy?useUnicode=true&characterEncoding=utf8
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.type=com.alibaba.druid.pool.DruidDataSource

讓bean實現UserDetails接口

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
public class User implements UserDetails {
  private Integer id;
  private String username;
  private String password;
  private Boolean enabled;
  private Boolean locked;
 
  private List<Role> roles;
 
  public List<Role> getRoles() {
    return roles;
  }
 
  public void setRoles(List<Role> roles) {
    this.roles = roles;
  }
 
  public Integer getId() {
    return id;
  }
 
  public void setId(Integer id) {
    this.id = id;
  }
 
  public void setUsername(String username) {
    this.username = username;
  }
 
  public void setPassword(String password) { this.password = password; }
 
  public void setEnabled(Boolean enabled) {
    this.enabled = enabled;
  }
 
  public void setLocked(Boolean locked) {
    this.locked = locked;
  }
 
  @Override
  public Collection<? extends GrantedAuthority> getAuthorities() {
    List<SimpleGrantedAuthority> authorities = new ArrayList<>();
    for (Role role : roles) {
      authorities.add(new SimpleGrantedAuthority("ROLE_" + role.getName()));
    }
    return authorities;
  }
 
  @Override
  public String getPassword() {
    return password;
  }
 
  public String getUsername() {
    return username;
  }
 
  //賬戶是否未過期
  @Override
  public boolean isAccountNonExpired() {
    return true;
  }
 
  //賬戶是否未鎖定
  @Override
  public boolean isAccountNonLocked() {
    return !locked;
  }
 
  @Override
  public boolean isCredentialsNonExpired() {
    return true;
  }
 
  @Override
  public boolean isEnabled() {
    return enabled;
  }
}

?
1
2
3
4
5
6
public class Role {
  private Integer id;
  private String name;
  private String nameZh;
...
}

userMapper

在類上直接加@Mapper或者在SpringBoot啟動類上配置全局的掃描@MapperScan(basePackages="")

?
1
2
3
4
5
6
@Mapper
public interface UserMapper {
  User loadUserByUsername(String username);
 
  List<Role> getUserRolesById(Integer id);
}

?
1
2
3
4
5
6
7
8
9
10
11
12
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
    PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
    "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.qwl.mysecuritydb.mapper.UserMapper">
  <select id="loadUserByUsername" resultType="com.qwl.mysecuritydb.bean.User">
    select * from user where username = #{username}
  </select>
  <select id="getUserRolesById" resultType="com.qwl.mysecuritydb.bean.Role">
    select * from role where id in(select rid from user_role where uid=#{id})
  </select>
</mapper>

userService 同樣也要繼承UserServiceDetails接口

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@Service
public class UserService implements UserDetailsService {
  @Autowired
  UserMapper userMapper;
 
  @Override
  public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
    User user =userMapper.loadUserByUsername(username);
    if(user==null){
      throw new UsernameNotFoundException("用戶不存在");
    }
    user.setRoles(userMapper.getUserRolesById(user.getId()));
    return user;
  }
}

HelloController

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
@RestController
public class HelloController {
  @GetMapping("/hello")
  public String hello(){
    return "hello security";
  }
 
  @GetMapping("/dba/hello")
  public String dba(){
    return "hello dba";
  }
 
  @GetMapping("/admin/hello")
  public String admin(){
    return "hello admin";
  }
 
  @GetMapping("/user/hello")
  public String user(){
    return "hello user";
  }
}

SecurityConfig

  • SercurityConfig需要繼承WebSecurityConfigurerAdapter類,并在類上加@Configuration
  • SpringSecurity5.0之后密碼必須加密
  • 把數據庫查出的用戶信息交給SpringSecurity處理
  • 配置httpSercurity
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {
  @Autowired
  UserService userService;
 
        //把數據庫查出的用戶信息交給SpringSecurity處理
  @Override
  protected void configure(AuthenticationManagerBuilder auth) throws Exception {
    auth.userDetailsService(userService);
  }
 
  @Bean
  PasswordEncoder passwordEncoder(){
    return new BCryptPasswordEncoder();
  }
 
  @Override
  protected void configure(HttpSecurity http) throws Exception {
    http.authorizeRequests()
        .antMatchers("/dba/**").hasRole("dba")
        .antMatchers("/admin/**").hasRole("admin")
        .antMatchers("/user/**").hasRole("user")
        .anyRequest().authenticated()
        .and()
        .formLogin()
        .permitAll()
        .and()
        .csrf().disable();
 
  }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:https://www.cnblogs.com/qiuwenli/p/13445594.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 免费高清在线 | 国产精品馆 | 国产精品免费久久久久影院 | 太大了轻点阿受不了小说h 四色6677最新永久网站 | 嫩草成人影院 | 免费观看毛片视频 | 娇妻被健身教练挺进小说阅读 | 国产一区二区在线观看视频 | 第一次不是你高清在线观看 | 亚洲午夜视频 | 国产成人久视频免费 | 欧洲肥女大肥臀 | 高清不卡日本v在线二区 | 亚洲日韩精品欧美一区二区 | 国产成人欧美 | 日本加勒比一区 | 久青草国产在线观看视频 | 桃花岛在线 | 国产成人免费视频 | 扒开黑女人p大荫蒂老女人 扒开大腿狠狠挺进视频 | 校服下的白嫩小乳尖h1v1 | 欧美日韩一区二区三区在线播放 | 亚洲26uuuu最新地址 | 青草香蕉精品视频在线观看 | naruto tube18动漫| 国产成人精品一区二三区 | 成人免费视频一区二区 | 成年人在线免费看 | 国产真实一区二区三区 | 亚洲黄色片免费看 | 99精品在线视频 | 欧美在线一二三区 | 免费一级毛片完整版在线看 | 激情婷婷综合久久久久 | 国产午夜视频在线观看网站 | ts人妖国产一区 | 好看的亚洲视频 | 小寡妇水真多好紧 | 日本xxxx69hd | 欧美一级xxx | 久久91精品国产91久 |