Mysql源码学习——用户认证原理与实现

来源:未知 责任编辑:责任编辑 发表时间:2014-01-06 18:17 点击:

 

前几节跟踪了Connection Manager和Thread Manager,在连接的过程中,还有一个身份认证的过程,就是大家所熟悉的

 

验证用户名和密码的过程,我们平时做一个系统的时候,很多时候都会涉及到身份验证。今天我们就来看下Mysql是如何进

 

行验证的。(注意是登录,不是登陆^_^)

 

一、用户认证原理

 

      我们在应用程序中实现验证的方式基本上都是创建一张用户表,里面至少包含username和password两个字段,

 

password基本上都是加密后进行存储的。作为数据库,对用户的限制较多,不是像我说的仅仅只有username和password

 

这么简单了。首先粗略的讲下访问控制。

 

     信息系统中,访问控制分为自主访问控制(DAC)和强制访问控制(MAC)。具体到DBMS,自主访问控制就是我们所熟悉

 

的GRANT,REVOKE,大多数数据库都支持自助的访问控制。强制访问控制就是ORACLE中的LABEL,只有很少的一些系统支持MAC。

 

严格来说,登录并不属于访问控制机制,而应该属于用户身份识别和认证。在Mysql中,将登录和DAC的相关接口都实现在了

 

sql_acl.cc中(其实说登录是用户拥有的一种权限也未尝不可,正如ORACLE中的CREATE SESSION,不过登录并不仅仅是一种权

 

限,还包含很多其他的属性),从文件名大家可以看出来,ACL即ACCESS CONTROL LIST,访问控制列表,这是实现访问控制的

 

基本方法。下图是Mysql的整个访问控制的流程。

 

 

    Mysql中用户管理模块的信息存储在系统表mysql.User中,这个表不仅仅存放了授权用户的基本信息,还存放一些权限

 

信息。我们首先大概看一下这个表的结构。

 

+-----------------------+-----------------------------------+------+-----+---------+-------+

 

| Field | Type | Null | Key | Default | Extra |

 

+-----------------------+-----------------------------------+------+-----+---------+-------+

 

| Host | char(60) | NO | PRI | | |

 

| User | char(16) | NO | PRI | | |

 

| Password | char(41) | NO | | | |

 

| Select_priv | enum('N','Y') | NO | | N | |

 

| Insert_priv | enum('N','Y') | NO | | N | |

 

| Update_priv | enum('N','Y') | NO | | N | |

 

| Delete_priv | enum('N','Y') | NO | | N | |

 

| Create_priv | enum('N','Y') | NO | | N | |

 

| Drop_priv | enum('N','Y') | NO | | N | |

 

| Reload_priv | enum('N','Y') | NO | | N | |

 

| Shutdown_priv | enum('N','Y') | NO | | N | |

 

| Process_priv | enum('N','Y') | NO | | N | |

 

| File_priv | enum('N','Y') | NO | | N | |

发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码:点击我更换图片
最新评论 更多>>

推荐热点

  • mysql-mmm
  • mysqldump命令——MySQL数据库备份还原
  • Oracle数据导入MySQL的快捷工具:MySQL Migration Toolkit
  • 简简单单储存过程——循环一个select结果集
  • MySQL数据库十大优化技巧
  • Mysql安装笔记
  • Mysql主主复制架构配置
  • Mysql的Procedure 参数为NULL问题分析
  • MySQL Stmt预处理提高效率问题的小研究
网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
Copyright © 2008-2015 计算机技术学习交流网. 版权所有

豫ICP备11007008号-1