视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
MySQL中权限管理的详图介绍
2020-11-09 09:10:00 责编:小采
文档


权限管理

MySQL权限系统通过下面两个阶段进行认证:

  • 对连接的用户进行身份认证,合法的用户通过认证,不合法的用户拒绝连接。

  • 对通过认证的合法用户授予相应的权限,用户可以通过再这些权限范围内对数据库做相应的操作。
    在权限存取过程中,主要涉及到mysql数据库下user表和db表。user表的数据结构如下:

    db表数据结构如下:

    表的说明:其中包含用户列、权限列、安全列和资源控制列。用的最频繁的是用户列和权限列,权限分为普通权限和管理权限。普通权限用户数据库的操作如select_priv、insert_priv等。管理权限主要用来对数据库进行管理的操作,比如process_priv、super_priv等。
    用户进行连接的时候,权限表的存取过程:

  • 先从user表中的host、user和password这三个字段中判断连接的ip、用户名以及密码是否存在表中,如果存在,则通过验证,否则拒绝连接。

  • 通过身份验证之后,按照以下权限表的顺序得到数据库权限:user->db->tables->priv->columns_priv。全局权限,覆盖局部权限。比如一个用户在user表中拥有选择权限,那么他将对所有数据中的所有表所有的列都有选择权限。

    权限查找详细描述:当用户通过权限认证之后,进行权限分配时候,按照user->db->tables_priv->columns_priv的顺序进行权限分配,即先检查权限表user,如果user表中对应的权限为Y,此时用户对应所有的数据库权限为Y,将不再检查db、tables_priv、columns_priv;如果为N,则到db表中进行查找用户对于具体数据库权限,如果得到db中的Y权限,则不在查找,否则检查tables_priv,看该数据库对应的具体表权限,如果为Y,则不在查找,否则检查columns_priv表,查看对应的具体列权限。这一点对于我们授予用户权限很重要。

  • 账号管理

    创建用户

    创建用户,可以使用grant语法创建或者直接操作user表。
    方法一:
    直接操作use表
    insert into user(Host,User,Password) values(“127.0.0.1”,”test”,password(“51testit”));
    方法二:
    格式 CREATE USER ‘username’@’host’ IDENTIFIED BY ‘password’;
    eg:CREATE USER ‘test’@’127.0.0.1’ IDENTIFIED BY ‘51testit’;

    创建之后,登录如下:

    MySQL加密方式: MYSQL323加密中生成的是16位字符串,而在MySQLSHA1中生存的是41位字符串,其中是不加入实际的密码运算中,通过观察在很多用户中都携带了”“,在实际破解过程中去掉”*”,也就是说MySQLSHA1加密的密码的实际位数是40位。
    Host字段描述

  • Host值可以是主机名或者IP号,或者locahost代表本地主机。

  • 可以再host列值前面使用通配符”%”和”_”,”%”代表匹配任何主机,空的Host值等于”%”。如”%.myweb.com”,匹配所有mysql.com域的所有主机。案例如下:

  • HostUser解析
    myweb.wangppspps,从myweb.wang连接
    %ppspps,从任何主机连接
    %任何用户,从任何主机连接
    122.1.35.127ppspps,从122.1.35.127连接
    122.1.35.%ppspps,从122.1.35.类型子网的任何主机连接

    查看用户权限

    对于上面创建的test,我没有进行任何授权操作,当我使用test用户去操作数据库时候,发现:

    没有数据库操作权限,怎样才能查看用户拥有的权限呢?
    查看权限
    方法一:
    show grants for test@127.0.0.1;
    方法二:
    查看user表中记录的权限。
    select * from mysql.user where user=’test’ and host=’127.0.0.1’ \G;

    授予权限

    语法格式如下:
    grant [privilege1|privilege2|all privileges] on dbName|.tableName 或 to user@hostName ;
    当给test用户授予xxpt选择权限时候:
    grant select On xxpt.* to test.127.0.0.1;
    db表发生了变化,新增加一条记录。但是user表并没有改变。如下:

    此时,可以使用test用户进行数据查询操作,但是不能进行增、删、改。于是授予其关于xxpt数据库的所有权限。
    grant all privileges on xxpt.* to test@127.0.0.1;
    用户test权限如下:

    此时可以更新数据

    管理权限sueper、process、file授予
    grant sueper,process,file On . to ‘test’@’127.0.0.1’;
    语句中on后面只能是.
    备注:usage 权限用于登录,不能进行任何操作。

    删除权限

    使用grant新增权限,使用revoke进行权限回收。当然回收权限,也可以直接对user、db、tables_priv和columns_priv表进行操作。但是usage权限是没法收回的。
    如回收test对所有数据库的读写权限:
    revoke select ,insert on . from test@127.0.0.1;

    修改密码

    1.使用mysqladmin
    2.使用set password for test@127.0.0.1 =password(‘isayhello’);
    3.通过grant usage
    grant usage on . to ‘test’@’127.0.0.1’ identified by ‘isayhello’;
    4.直接修改user表
    update user set Password=password(“newpassword”) where ***;

    补充mysql中权限

    权限

    权限级别

    权限说明

    CREATE

    数据库、表或索引

    创建数据库、表或索引权限

    DROP

    数据库或表

    删除数据库或表权限

    GRANT OPTION

    数据库、表或保存的程序

    赋予权限选项

    REFERENCES

    数据库或表

    ALTER

    更改表,比如添加字段、索引等

    DELETE

    删除数据权限

    INDEX

    索引权限

    INSERT

    插入权限

    SELECT

    查询权限

    UPDATE

    更新权限

    CREATE VIEW

    视图

    创建视图权限

    SHOW VIEW

    视图

    查看视图权限

    ALTER ROUTINE

    存储过程

    更改存储过程权限

    CREATE ROUTINE

    存储过程

    创建存储过程权限

    EXECUTE

    存储过程

    执行存储过程权限

    FILE

    服务器主机上的文件访问

    文件访问权限

    CREATE TEMPORARY TABLES

    服务器管理

    创建临时表权限

    LOCK TABLES

    服务器管理

    锁表权限

    CREATE USER

    服务器管理

    创建用户权限

    PROCESS

    服务器管理

    查看进程权限

    RELOAD

    服务器管理

    执行flush-hosts, flush-logs, flush-privileges, flush-status, flush-tables, flush-threads, refresh, reload等命令的权限

    REPLICATION CLIENT

    服务器管理

    复制权限

    REPLICATION SLAVE

    服务器管理

    复制权限

    SHOW DATABASES

    服务器管理

    查看数据库权限

    SHUTDOWN

    服务器管理

    关闭数据库权限

    SUPER

    服务器管理

    执行kill线程权限

    MYSQL的权限如何分布,就是针对表可以设置什么权限,针对列可以设置什么权限等等,这个可以从官方文档中的一个表来说明:

    权限分布

    可能的设置的权限

    表权限

    ‘Select’, ‘Insert’, ‘Update’, ‘Delete’, ‘Create’, ‘Drop’, ‘Grant’, ‘References’, ‘Index’, ‘Alter’

    列权限

    ‘Select’, ‘Insert’, ‘Update’, ‘References’

    过程权限

    ‘Execute’, ‘Alter Routine’, ‘Grant’

    下载本文
    显示全文
    专题