Spring Security(三)

一、RBAC

在这里插入图片描述

RBAC:用户是属于角色的,角色拥有权限的集合。用户数据某个角色,他就具有角色对应的权限。
权限:能对资源的操作,比如增加,修改,删除,查看等等。
角色:自定义的,表示权限的集合。一个角色可以有多个权限。
RBAC设计中的表:
1.用户表
:用户认证(登录用到的表)
用户名,密码,是否启用,是否锁定等信息
2.角色表:定义角色信息
角色名称,角色的描述
3.用户和角色的关系表:用户和角色是多对多的关系
一个用户可以有多个角色,一个角色可以有多个用户
4.权限表,角色和权限的关系表
角色可以有哪些权限

二、Spring Specurity中认证的接口和类

1.UserDetails接口类:

String getPassword();  // 账户密码

String getUsername();  // 用户名称

boolean isAccountNonExpired();  // 账号是否过期

boolean isAccountNonLocked();  // 账号是否锁定

boolean isCredentialsNonExpired();  // 证书是否过期

boolean isEnabled();  // 账号是否启用

Collection<? extends GrantedAuthority> getAuthorities();  // 权限集合

User实现类

2.User实现类

可以:自定义实现UserDetails接口,作为你的系统中的用户类。这个类可以交给spring security使用
public User(String username, String password, Collection<? extends GrantedAuthority> authorities) {
    this(username, password, true, true, true, true, authorities);
}
public User(String username, String password, boolean enabled, boolean accountNonExpired, boolean credentialsNonExpired, boolean accountNonLocked, Collection<? extends GrantedAuthority> authorities) {
    if (username != null && !"".equals(username) && password != null) {}

3.UserDetailsService接口

主要作用:获取用户信息,得到是UserDetails对象。一般项目中都需要自定义类实现这个接口,从数据库中获取数据。
UserDetailsService接口有一个方法需要实现:
 UserDetails loadUserByUsername(String var1) ;根据用户名称,获取用户信息(用户名称,密码,角色结合,是否可用,是否锁定等信息)

4.UserDetailsService接口实现类

(1)InMemoryUserDetailsManager:在内存中维护用户信息
优点:使用方便
缺点:数据不是持久的。系统重启后数据恢复原样
createUser:创建用户
deleteUser:删除用户
userExists:用户是否存在
loadUserByUsername:通过用户名加载用户
changePassword:更改用户密码
数据库文件:

create table users(username varchar_ignorecase(50) not null primary key,password varchar_ignorecase(500) not null,enabled boolean not null);
create table authorities (username varchar_ignorecase(50) not null,authority varchar_ignorecase(50) not null,constraint fk_authorities_users foreign key(username) references users(username));
create unique index ix_auth_username on authorities (username,authority);
        
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值