zoukankan      html  css  js  c++  java
  • spring security方法一 自定义数据库表结构

    Spring Security默认提供的表结构太过简单了,其实就算默认提供的表结构很复杂,也无法满足所有企业内部对用户信息和权限信息管理的要求。基本上每个企业内部都有一套自己的用户信息管理结构,同时也会有一套对应的权限信息体系,如何让Spring Security在这些已有的数据结构之上运行呢?

    自定义表结构

    -- 角色
    create table role(
        id bigint,
        name varchar(50),
        descn varchar(200)
    );
    alter table role add constraint pk_role primary key(id);
    alter table role alter column id bigint generated by default as identity(start with 1);
    
    -- 用户
    create table user(
        id bigint,
        username varchar(50),
        password varchar(50),
        status integer,
        descn varchar(200)
    );
    alter table user add constraint pk_user primary key(id);
    alter table user alter column id bigint generated by default as identity(start with 1);
    
    -- 用户角色连接表
    create table user_role(
        user_id bigint,
        role_id bigint
    );
    alter table user_role add constraint pk_user_role primary key(user_id, role_id);
    alter table user_role add constraint fk_user_role_user foreign key(user_id) references user(id);
    alter table user_role add constraint fk_user_role_role foreign key(role_id) references role(id);

    上述共有三张表,其中user用户表,role角色表为保存用户权限数据的主表,user_role为关联表。user用户表,role角色表之间为多对多关系,就是说一个用户可以有多个角色。ER图如下所示:

    数据库表关系

    初始化数据

    创建两个用户,admin和user。admin用户拥有“管理员”角色,user用户拥有“用户”角色。

    insert into user(id,username,password,status,descn) values(1,'admin','admin',1,'管理员');
    insert into user(id,username,password,status,descn) values(2,'user','user',1,'用户');
    
    insert into role(id,name,descn) values(1,'ROLE_ADMIN','管理员角色');
    insert into role(id,name,descn) values(2,'ROLE_USER','用户角色');
    
    insert into user_role(user_id,role_id) values(1,1);
    insert into user_role(user_id,role_id) values(1,2);
    insert into user_role(user_id,role_id) values(2,2);

    获得自定义用户权限信息

    现在我们要在这样的数据结构基础上使用Spring Security,Spring Security所需要的数据只是为了处理两种情况,一是判断登录用户是否合法,二是判断登陆的用户是否有权限访问受保护的系统资源。

    我们所要做的工作就是在现有数据结构的基础上,为Spring Security提供这两种数据。

    处理用户登陆

    select username,password,status as enabled
    from user
    where username=?

    检验用户权限

    select u.username,r.name as authority
      from user u
      join user_role ur
        on u.id=ur.user_id
      join role r
        on r.id=ur.role_id
     where u.username=?"/>

    将语句配置到xml中

        <authentication-provider>
            <jdbc-user-service data-source-ref="dataSource"
                1users-by-username-query="select username,password,status as enabled
                                             from user
                                            where username=?"
                2authorities-by-username-query="select u.username,r.name as authority
                                                 from user u
                                                 join user_role ur
                                                   on u.id=ur.user_id
                                                 join role r
                                                   on r.id=ur.role_id
                                                where u.username=?"/>
        </authentication-provider>

    users-by-username-query为根据用户名查找用户,系统通过传入的用户名查询当前用户的登录名,密码和是否被禁用这一状态。

    authorities-by-username-query为根据用户名查找权限,系统通过传入的用户名查询当前用户已被授予的所有权限。

  • 相关阅读:
    Goal driven performance optimization
    Using SHOW PROCESSLIST and mysqladmin debug Output in Conjunction with SHOW INNODB STATUS
    Concurrent inserts on MyISAM and the binary log
    A better SHOW TABLE STATUS
    show table status
    A Flock Of Tasty Sources On How To Start Learning High Scalability
    PostgreSQL Hardware Performance Tuning
    Choosing proper innodb_log_file_size
    ffmpeg 常用命令
    opencv 知识点笔记
  • 原文地址:https://www.cnblogs.com/wenjieyatou/p/6116375.html
Copyright © 2011-2022 走看看