用户与权限管理

文章目录

  • 用户与权限管理
    • 1. 用户管理
      • 1.1 MYSQL用户
      • 1.2 登录MySQL服务器
      • 1.3 创建用户
      • 1.4 修改用户
      • 1.5 删除用户
      • 1.6 修改密码
        • 1. 修改当前用户密码
        • 2. 修改其他用户密码
      • 1.7 MYSQL8密码管理
    • 2. 权限管理
      • 2.1 权限列表
      • 2.2 授予权限的原则
      • 2.3 授予权限
      • 2.4 查看权限
      • 2.5 收回权限
    • 3. 权限表
      • 3.1 user表
      • 3.2 db表
      • 3.3 table_priv和columns_priv表
      • 3.4 procs_priv表--- 存储过程和存储函数权限表
    • 4. 访问控制
    • 5. 角色管理
        • 5.1 创建角色
        • 5.2 给角色赋予权限
        • 5.3 查看角色权限
        • 5.4 回收角色权限
        • 5.5 删除角色
        • 5.6给用户赋予角色
        • 5.7激活角色
        • 5.8撤销用户角色
        • 5.9 设置强制角色(mandatory role)

用户与权限管理

1. 用户管理

1.1 MYSQL用户

MYSQL用户分为普通用户root用户

  • root用户超级管理员,拥有所有权限,包括创建用户、删除用户和修改用户密码登管理权限
  • 普通用户:只拥有被授权的各种权限

MYSQL提供了很多语句来管理用户账号。 包括登录、退出、创建用户、删除用户、密码管理、权限管理等。

MYSQL数据库的安全性需要账户管理来保证

1.2 登录MySQL服务器

启动MySQL服务后,可以通过mysql命令来登录MySQL服务器,命令如下:

mysql –h hostname|hostIP –P port –u username –p DatabaseName –e "SQL语句"
-h参数 后面接主机名或者主机IP,hostname为主机,hostIP为主机IP。
-P参数 后面接MySQL服务的端口,通过该参数连接到指定的端口。MySQL服务的默认端口是3306,
不使用该参数时自动连接到3306端口,port为连接的端口号。
-u参数 后面接用户名,username为用户名。
-p参数 会提示输入密码。
DatabaseName参数 指明登录到哪一个数据库中。如果没有该参数,就会直接登录到MySQL数据库
中,然后可以使用USE命令来选择数据库。
-e参数 后面可以直接加SQL语句。登录MySQL服务器以后即可执行这个SQL语句,然后退出MySQL
服务器。
  • 如:mysql -h localhost -P 3306 -p emp3 -e "select * from test";用户与权限管理_第1张图片
    也可以先登录数据库:mysql -u root -p先登录,进mysql数据库再查询用户与权限管理_第2张图片

1.3 创建用户

  • 创建用户语法格式:CREATE USER 用户名 [IDENTIFIED BY '密码'][,用户名 [IDENTIFIED BY '密码']];

      用户名参数表示新建用户的账户,由 用户(User) 和 主机名(Host) 构成;
      “[ ]”表示可选,也就是说,可以指定用户登录时需要密码验证,也可以不指定密码验证,这样用户可以直接登录。
      不过,不指定密码的方式不安全,不推荐使用。如果指定密码值,这里需要使用IDENTIFIED BY指定明文密码值。
      	
      CREATE USER语句可以同时创建多个用户。
    
  • 如:CREATE USER zhang3 IDENTIFIED BY '123123'; # 默认host是 %再次创建同一个用户会报错,提示用户已经存在
    用户与权限管理_第3张图片
    在这里插入图片描述
    用户与权限管理_第4张图片

  • 再次使用localhost创建相同用户会创建成功:CREATE USER 'zhang3'@'localhost' IDENTIFIED BY '123456';host和user共同唯一
    在这里插入图片描述
    查询所有用户必须在mysql数据库下的:
    用户与权限管理_第5张图片

    先exit退出后,使用创建的zhang3账号登录:
    用户与权限管理_第6张图片
    查看数据库显示比较少,是因为默认只有登录权限
    用户与权限管理_第7张图片

1.4 修改用户

  • 修改用户名:注意修改后一定要刷新权限,不然可能用原账号密码还会登录进去,反而新账号密码登录不上

    UPDATE mysql.user SET USER='wang5' WHERE USER='zhang3';
    FLUSH PRIVILEGES;
    

    用户与权限管理_第8张图片

1.5 删除用户

推荐drop user命令会删除用户以及对应的权限,执行命令后你会发现mysql.user表和mysql.db表的相应记录都消失了

不推荐:通过 DELETE FROM USER u WHERE USER='wang5' 进行删除,系统会有残留信息保留

  • 方式1:使用DROP方式删除(推荐)

    DROP USER user[,user];
    

    如:不加@默认删除host为%的用户

    DROP USER zhang3 ; # 默认删除host为%的用户
    DROP USER 'zhang3'@'localhost';
    

    用户与权限管理_第9张图片
    用户与权限管理_第10张图片

  • 方式2:使用DELETE方式删除,执行完后要记得刷新权限**(不推荐)**

    DELETE FROM mysql.user WHERE Host=’hostname’ AND User=’username’;
    FLUSH PRIVILEGES;
    

    如:

    DELETE FROM mysql.user WHERE Host='localhost' AND User='Emily';
    FLUSH PRIVILEGES;
    

1.6 修改密码

1. 修改当前用户密码

mysql5.7之前的修改用户密码语法,现在没有了

# 修改当前用户的密码:(MySQL5.7测试有效)
SET PASSWORD = PASSWORD('123456');
  • 方式1:使用ALTER USER命令来修改当前用户密码 。用户可以使用ALTER命令来修改自身密码

    ALTER USER USER() IDENTIFIED BY 'new_password';
    

    用户与权限管理_第11张图片

  • 使用SET语句来修改当前用户密码。使用root用户登录MySQL后,可以使用SET语句来修改密码

    SET PASSWORD='new_password';
    

该语句会自动将密码加密后再赋给当前用户,即用户设置的密码会加密后再设置为当前用户密码
用户与权限管理_第12张图片
查看密码:加密后的密文
用户与权限管理_第13张图片

2. 修改其他用户密码
  • 方式1:使用ALTER语句来修改普通用户的密码,语法:

    ALTER USER user [IDENTIFIED BY '新密码']
    [,user[IDENTIFIED BY '新密码']];
    

    如:在root用户下修改zhang3用户密码alter user 'zhang3' @'%' identified by '123456789';
    用户与权限管理_第14张图片

  • 方式2:使用SET命令来修改普通用户的密码

    SET PASSWORD FOR 'username'@'hostname'='new_password';
    

    用户与权限管理_第15张图片

  • 方式3:使用UPDATE语句修改普通用户的密码(不推荐)

    UPDATE MySQL.user SET authentication_string=PASSWORD("123456")
    WHERE User = "username" AND Host = "hostname";
    

1.7 MYSQL8密码管理

mysql中记录使用过的历史密码,目前包含一下密码管理功能:

  • 密码过期:要求定期修改密码
  • 密码重用限制:不允许使用旧密码
  • 密码强度评估,要求使用高强度密码
    在这里插入图片描述
  1. 密码过期策略
    在MySQL中,数据库管理员可以 手动设置 账号密码过期,也可以建立一个 自动 密码过期策略。过期策略可以是 全局的 ,也可以为 每个账号 设置单独的过期策略。

    ALTER USER user PASSWORD EXPIRE;
    

    如:ALTER USER 'kangshifu'@'localhost' PASSWORD EXPIRE;

    方式①:使用SQL语句更改该变量的值并持久化

    SET PERSIST default_password_lifetime = 180; # 建立全局策略,设置密码每隔180天过期
    

    方式②:配置文件my.cnf中进行维护

    [mysqld]
    default_password_lifetime=180 #建立全局策略,设置密码每隔180天过期
    

    手动设置指定时间过期方式2:单独设置

     每个账号既可延用全局密码过期策略,也可单独设置策略。在 CREATE USER 和 ALTER USER 语句上加入 PASSWORD EXPIRE 选项可实现单独设置策略。下面是一些语句示例。
    
    #设置kangshifu账号密码每90天过期:
    CREATE USER 'kangshifu'@'localhost' PASSWORD EXPIRE INTERVAL 90 DAY;
    ALTER USER 'kangshifu'@'localhost' PASSWORD EXPIRE INTERVAL 90 DAY;
    #设置密码永不过期:
    CREATE USER 'kangshifu'@'localhost' PASSWORD EXPIRE NEVER;
    ALTER USER 'kangshifu'@'localhost' PASSWORD EXPIRE NEVER;
    #延用全局密码过期策略:
    CREATE USER 'kangshifu'@'localhost' PASSWORD EXPIRE DEFAULT;
    ALTER USER 'kangshifu'@'localhost' PASSWORD EXPIRE DEFAULT;
    
  2. 密码重用策略

    手动设置密码重用方式1:全局

    • 方式①:使用SQL

      SET PERSIST password_history = 6; #设置不能选择最近使用过的6个密码
      SET PERSIST password_reuse_interval = 365; #设置不能选择最近一年内的密码
      

      用户与权限管理_第16张图片

    • 方式②:my.cnf配置文件

      [mysqld]
      password_history=6
      password_reuse_interval=365
      

    手动设置密码重用方式2:单独设置

    #不能使用最近5个密码:
    CREATE USER 'kangshifu'@'localhost' PASSWORD HISTORY 5;
    ALTER USER 'kangshifu'@'localhost' PASSWORD HISTORY 5;
    #不能使用最近365天内的密码:
    CREATE USER 'kangshifu'@'localhost' PASSWORD REUSE INTERVAL 365 DAY;
    ALTER USER 'kangshifu'@'localhost' PASSWORD REUSE INTERVAL 365 DAY;
    #既不能使用最近5个密码,也不能使用365天内的密码
    CREATE USER 'kangshifu'@'localhost'
    PASSWORD HISTORY 5
    PASSWORD REUSE INTERVAL 365 DAY;
    ALTER USER 'kangshifu'@'localhost
    PASSWORD HISTORY 5
    PASSWORD REUSE INTERVAL 365 DAY;
    

2. 权限管理

2.1 权限列表

MYSQL的权限分布:

权限分布 可能的设置的权限
表权限 ‘Select’、‘Insert’,‘Update’、‘Delete’、’Create‘、‘Drop’、‘Grant’、‘Reference’、‘Index’、‘Alter’
列权限 ‘Select’、‘Insert’,‘Update’,‘Reference’
过程权限 ‘Execute’、‘Ater Routine’,‘Grant’
  • 查看权限列表:show privileges;
    用户与权限管理_第17张图片

2.2 授予权限的原则

权限控制主要是出于安全因素,因此需要遵循以下几个 经验原则 :

  1. 只授予能 满足需要的最小权限 ,防止用户干坏事。比如用户只是需要查询,那就只给select权限就可以了,不要给用户赋予update、insert或者delete权限。
  2. 创建用户的时候 限制用户的登录主机 ,一般是限制成指定IP或者内网IP段。
  3. 为每个用户 设置满足密码复杂度的密码
  4. 定期清理不需要的用户 ,回收权限或者删除用户

2.3 授予权限

用户是数据库的使用者,我们可以通过给用户授予访问数据库中资源的权限,来控制使用者对数据库的访问,消除安全隐患。给用户授权的方式有 2 种

  • 把角色赋予用户给用户授权

  • 直接给用户授权

    授权命令:

    GRANT 权限1,权限2,…权限n ON 数据库名称.表名称 TO 用户名@用户地址 [IDENTIFIED BY ‘密码口令’];
    
  • 例:授权前用户与权限管理_第18张图片

    在root账户下授权: 在这里插入图片描述
    授权后:此时zhang3用户可以更新表用户与权限管理_第19张图片

  • 授予所有权限:grant all privileges on *.* to 'zhang3'@'%';授予所有权限后的用户虽然有对数据库的操作权限,但不具有赋予别的角色权限的能力。
    用户与权限管理_第20张图片
    授权后权限:用户与权限管理_第21张图片

  • 授予通过网络方式登录的joe用户 ,对所有库所有表的全部权限,密码设为123。注意这里唯独不包括grant的权限

    GRANT ALL PRIVILEGES ON *.* TO joe@'%' IDENTIFIED BY '123';
    

用户与权限管理_第22张图片

2.4 查看权限

  • 查看当前用户权限:

    SHOW GRANTS;
    # 或
    SHOW GRANTS FOR CURRENT_USER;
    # 或
    SHOW GRANTS FOR CURRENT_USER();
    
  • 查看某些用户权限:

    SHOW GRANTS FOR 'user'@'主机地址' ;
    

2.5 收回权限

收回权限就是取消已经赋予用户的某些权限。收回用户不必要的权限可以在一定程度上保证系统的安全性

  • MySQL中使用 REVOKE语句 取消用户的某些权限。使用REVOKE收回权限之后,用户账户的记录将从 db、host、tables_priv和columns_priv表中删除,但是用户账户记录仍然在user表中保存(删除user表中的账户记录使用DROP USER语句)。

  • 注意:在将用户账户从user表删除之前,应该收回相应用户的所有权限。

收回权限命令:

REVOKE 权限1,权限2,…权限n ON 数据库名称.表名称 FROM 用户名@用户地址;

用户与权限管理_第23张图片

  • 注意:更新权限有需要重新登录才会生效
    用户与权限管理_第24张图片

3. 权限表

  • 这里的权限表是数据库中的mysql数据库
    用户与权限管理_第25张图片

    用户与权限管理_第26张图片

3.1 user表

user表:是用户的权限表

user表是MySQL中最重要的一个权限表, 记录用户账号和权限信息 ,有49个字段。如下图:

用户与权限管理_第27张图片

这些字段可以分成4类,分别是范围列(或用户列)、权限列、安全列和资源控制列。用户与权限管理_第28张图片
用户与权限管理_第29张图片
用户与权限管理_第30张图片

  • 查看字段:DESC mysql.user;用户与权限管理_第31张图片

  • 查看用户, 以列的方式显示数据:SELECT * FROM mysql.user \G;

  • 查询特定字段:

    SELECT host,user,authentication_string,select_priv,insert_priv,drop_priv FROM mysql.user;
    

    用户与权限管理_第32张图片

3.2 db表

db表:是对具体数据库的权限操作:

  • 使用DESCRIBE查看db表的基本结构: DESCRIBE mysql.db;Host、Db、User共同构成联合主键用户与权限管理_第33张图片
  1. 用户列

    db表用户列有3个字段,分别是Host、User、Db。这3个字段分别表示主机名、用户名和数据库名。表示从某个主机连接某个用户对某个数据库的操作权限,这3个字段的组合构成了db表的主键

  2. 权限列
    Create_routine_privAlter_routine_priv这两个字段决定用户是否具有创建和修改存储过程的权限

3.3 table_priv和columns_priv表

  • 查看具体某个表的权限:desc table_privHost、Db、User、Table_name共同构成联合主键 在这里插入图片描述

  • 查看具体某个表的列的权限:desc table_privHost、Db、User、Table_name、Column_priv共同构成联合主键 用户与权限管理_第34张图片

3.4 procs_priv表— 存储过程和存储函数权限表

  • 查看存储过程和存储函数权限:desc table_privHost、Db、User、Table_name、Column_priv共同构成联合主键 用户与权限管理_第35张图片

4. 访问控制

MYSQLD的访问控制: 正常情况下,并不希望每个用户都可以执行数据库操作。当MYSQL允许一个用户执行各种操作时,会先 核实 用户向mysql发出的连接请求,然后 确认 用户的操作请求 是否被允许

MYSQL访问控制分为两个阶段连接核实阶段请求核实阶段

  1. 连接核实阶段

    当用户试图连接MySQL服务器时,服务器基于用户的身份以及用户是否能提供正确的密码 验证身份 来确定接受或者拒绝连接。即客户端用户会在连接请求中提供用户名、主机地址、用户密码,MySQL服务器 接收到用户请求后,会使用user表中的host、user和authentication_string这3个字段匹配客户端提供信息。

    服务器只有在user表记录的Host和User字段匹配客户端主机名和用户名,并且提供正确的密码时才接受连接。如果连接核实没有通过,服务器就完全拒绝访问否则,服务器接受连接,然后进入阶段2等待用户请求

  2. 请求核实阶段

    一旦建立了连接,服务器就进入了访问控制的阶段2,也就是请求核实阶段。对此连接上进来的每个请 求,服务器检查该请求要执行什么操作、是否有足够的权限来执行它,这正是需要授权表中的权限列发挥作用的地方。这些权限可以来自user、db、table_priv和column_priv表。

    确认权限时,MySQL首先 检查user表 ,如果指定的权限没有在user表中被授予,那么MySQL就会继续 检查db表 ,db表是下一安全层级,其中的权限限定于数据库层级,在该层级的SELECT权限允许用户查看指定数据库的所有表中的数据;如果在该层级没有找到限定的权限,则MySQL继续 检查tables_priv表 以及 columns_priv表 ,如果所有权限表都检查完毕,但还是没有找到允许的权限操作,MySQL将 返回错误信息 ,用户请求的操作不能执行,操作失败。请求核实过程如下图:
    用户与权限管理_第36张图片

    用户与权限管理_第37张图片
    例:登录zhang3用户属于请求连接核实阶段,登录成功后执行查询操作属于请求核实阶段
    用户与权限管理_第38张图片

5. 角色管理

角色是MYSQL8.0菜引入的新功能,在MYSQL中,角色是权限的集合可以为角色添加或移除权限。 用户可以被赋予角色,同时也被授权角色包含的权限。 对角色进行操作需要较高的权限。并且向用户账户一样,角色可以拥有授予和撤销的权限。

引入角色的目的:是 方便管理拥有相同权限的用户恰当的权限设定,可以确保数据的安全性,这是至关重要的。用户与权限管理_第39张图片

实际应用中,为了安全性,需要给用户授予权限。当用户数量较多时,为了避免单独给一个用户授予多个权限。可以先 将权限集合放入角色 中,再 赋予用户相应的角色

5.1 创建角色

创建角色使用 CREATE ROLE 语句,语法如下:

CREATE ROLE 'role_name'[@'host_name'] [,'role_name'[@'host_name']]...

角色名称的命名规则和用户名类似。如果 host_name省略,默认为% , role_name不可省略 ,不可为空。

例:创建管理员角色: create role 'manager'@'%';
创建boss角色:CREATE ROLE 'boss'@'%';
在这里插入图片描述在这里插入图片描述

5.2 给角色赋予权限

创建角色之后,默认这个角色是没有任何权限的,需要给角色授权。给角色授权的语法结构是:

GRANT privileges ON table_name TO 'role_name'[@'host_name'];

上述语句中privileges代表权限的名称,多个权限以逗号隔开。可使用SHOW PRIVILEGES\G;语句查询权限名称,下图列出了部分权限列表:
用户与权限管理_第40张图片

  • 例:给manager和boss角色分别授予权限
    在这里插入图片描述
5.3 查看角色权限

赋予角色权限之后,我们可以通过 SHOW GRANTS for 角色名 语句,来查看权限是否创建成功了。

只要你创建了一个角色,系统就会自动给你一个“ USAGE ”权限,意思是 连接登录数据库的权限

  • 例:查询manager角色的权限:show grants for 'manager';,其中USAGE权限是自动授予的连接登录数据库的权限
    用户与权限管理_第41张图片
5.4 回收角色权限

角色授权后,可以对角色的权限进行维护,对权限进行添加或撤销。添加权限使用GRANT语句,与角色授权相同。撤销角色或角色权限使用REVOKE语句。

修改了角色的权限,会影响拥有该角色的账户的权限。撤销角色权限的SQL语法如下:REVOKE privileges ON tablename FROM 'rolename';

  • 例:回收manager角色更新emp3数据的权限
    在这里插入图片描述
5.5 删除角色

当需要对业务重新整合的时候,可能就需要对之前创建的角色进行清理,删除一些不会再使用的角色,删除角色语法如下:

DROP ROLE role [,role2]...
  • 例:

    用户与权限管理_第42张图片

5.6给用户赋予角色

角色创建并授权后,要赋给用户并处于 激活状态 才能发挥作用。给用户添加角色可使用GRANT语句,语法形式如下:

GRANT role [,role2,...] TO user [,user2,...];

在上述语句中,role代表角色,user代表用户。可将多个角色同时赋予多个用户,用逗号隔开即可。

  • 如:给用户zhang3赋予manager权限
    用户与权限管理_第43张图片
  • 给用户添加角色后,用户登录后查询当前角色,如果角色未激活,结果将显示NONE。SQL语句如下:SELECT CURRENT_ROLE();
    用户与权限管理_第44张图片
5.7激活角色

方式1:使用 set default role 命令激活角色

  • 例:激活用户zhang3的manager角色

    set default role 'manager'@'%' to 'zhang3'@'%';
    

    用户与权限管理_第45张图片
    用户zhang3重新登录进来有了管理员角色
    用户与权限管理_第46张图片

方式2:activate_all_roles_on_login设置为ON

对 所有角色永久激活 。运行这条语句之后,用户才真正拥有了赋予角色的所有权限

SET GLOBAL activate_all_roles_on_login=ON;
mysql> show variables like 'activate_all_roles_on_login';
+-----------------------------+-------+
| Variable_name | Value |
+-----------------------------+-------+
| activate_all_roles_on_login | OFF |
+-----------------------------+-------+
1 row in set (0.00 sec)
5.8撤销用户角色

撤销用户角色语法如下:REVOKE role FROM user;

  • 例:撤销zhang3的manager角色
    用户与权限管理_第47张图片
    撤销后zhang3登录没有了emp3数据的权限
    用户与权限管理_第48张图片
5.9 设置强制角色(mandatory role)
  • 方式1:服务启动前设置

    [mysqld]
    mandatory_roles='role1,role2@localhost,r3@%.atguigu.com'
    
  • 方式2:运行时设置

    SET PERSIST mandatory_roles = 'role1,role2@localhost,r3@%.example.com'; #系统重启后仍然
    有效
    SET GLOBAL mandatory_roles = 'role1,role2@localhost,r3@%.example.com'; #系统重启后失效
    

你可能感兴趣的:(oracle,数据库)