2022年数据库和表权限 .pdf
《2022年数据库和表权限 .pdf》由会员分享,可在线阅读,更多相关《2022年数据库和表权限 .pdf(8页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、MySQL 安全性指南 (2)文章地址: http:/www.ykzj.org/article.php?articleid=10642.1.3 数据库和表权限下列权限运用于数据库和表上的操作。ALTER允许你使用 ALTER TABLE 语句,这其实是一个简单的第一级权限,你必须由其他权限,这看你想对数据库实施什么操作。 CREATE允许你创建数据库和表,但不允许创建索引。 DELETE允许你从表中删除现有记录。 DROP允许你删除(抛弃)数据库和表,但不允许删除索引。 INDEX允许你创建并删除索引。 REFERENCES目前不用。 SELECT允许你使用 SELECT 语句从表中检索数据。
2、对不涉及表的SELECT 语句就不必要,如 SELECT NOW()或SELECT 4/2 。 UPDATE允许你修改表中的已有的记录。 2.1.4 管理权限下列权限运用于控制服务器或用户授权能力的操作的管理性操作。FILE允许你告诉服务器读或写服务器主机上的文件。该权限不应该随便授予,它很危险,见“回避授权表风险”。服务器确实较谨慎地保持在一定范围内使用该权限。你只能读任何人都能读的文件。你正在写的文件必须不是现存的文件,这防止你迫使服务器重写重要文件,如/etc/passwd 或属于别人的数据名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - -
3、- - - - 名师精心整理 - - - - - - - 第 1 页,共 8 页 - - - - - - - - - 库的数据目录。如果你授权 FILE权限,确保你不以 UNIX 的root 用户运行服务器,因为 root 可在文件系统的任何地方创建新文件。如果你以一个非特权用户运行服务器,服务器只能在给用户能访问的目录中创建文件。GRANT允许你将你自己的权限授予别人,包括GRANT。 PROCESS允许你通过使用 SHOW PROCESS语句或mysqladmin process 命令查看服务器内正在运行的线程(进程)的信息。这个权限也允许你用KILL语句或mysqladmin kill命
4、令杀死线程。你总是能看到或杀死你自己的线程。PROCESS权限赋予你对任何线程做这些事情的能力。RELOAD允许你执行大量的服务器管理操作。你可以发出FLUSH 语句,你也能指性 mysqladmin的reload 、refresh、flush-hosts、flush-logs、flush-privileges和flush-tables等命令。 SHUTDOWN允许你用 mysqladmin shutdown 关闭服务器。 在user、db和host 表中,每一个权限以一个单独的列指定。这些列全部声明为一个ENUM(N,Y) 类型,所以每个权的缺省值是“N ”。在tables_priv和col
5、umns_priv 中的权限以一个 SET 表示,它允许权限用一个单个列以任何组合指定。这两个表比其他三个表更新,这就是为什么它们使用更有效的表示方式的原因。(有可能在未来,user、db和host 表也用一个 SET 类型表示。)在tables_priv表中的Table_priv 列被定义成:SET( Select , Insert , Update , Delete , Create , Drop , Grant , References , Index , Alter )在coloums_priv 表中的Column_priv 列被定义成: SET( Select , Insert ,
6、Update , References )列权限比表权限少,因为列级较少的权限有意义。例如你能创建一个表,但你不能创建一个孤立的列。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 8 页 - - - - - - - - - user表包含某些在其他授权表不存在的权限的列: File_priv 、Process_priv 、Reload_priv 和Shutdown_priv。这些权限运用于你让服务器执行的与任何特定数据库或表不相关的操作。如允许一个用户根据当前数据库是什么
7、来关闭数据库是毫无意义的。2.2 服务器如何控制客户访问在你使用 MySQL 时,客户访问控制有两个阶段。第一阶段发生在你试图连接服务器时。服务器查找user表看它是否能找到一个条目匹配你的名字、你正在从那儿连接的主机和你提供的口令。如果没有匹配,你就不能连接。如果有一个匹配,建立连接并继续第二阶段。在这个阶段,对于每一个你发出的查询,服务器检查授权表看你是否有足够的权限执行查询,第二阶段持续到你与服务器对话的结束。本小节详细介绍 MySQL 服务器用于将授权表条目匹配到来的连接请求或查询的原则,这包括在授权表范围列中合法的值的类型、结合授权表中的权限信息的方式和表中条目被检查的次序。2.2.
8、1 范围列内容一些范围列要求文字值,但它们大多数允许通配符或其他特殊值。Host 一个Host列值可以是一个主机名或一个IP地址。值 localhost意味着本地主机,但它只在你用一个localhost主机名时才匹配,而不是你在使用主机名时。假如你的本地主机名是并且在user表中有对你的两条记录,一个有一个Host值或localhost,而另一个有 ,有localhost的记录将只当你连接 localhost时匹配,其他在只在连接 时才匹配。如果你想让客户能以两种方式连接,你需要在 user表中有两条记录。你也可以用通配符指定 Host值。可以使用 SQL 的模式字符“ % ”和“_”并具有当
9、你在一个查询中使用LIKE算符同样的含义(不允许 regex算符)。 SQL 模式字符都能用于主机名和IP地址。如 %wisc.edu匹配任何 wisc.edu 域内的主机,而 %.edu匹配任何教育学院的主机。类似地,192.168.%匹配任何在 192.168 B类子网的主机,而 192.168.3.% 匹配任何在 192.168.3 C 类子网的主机。% 值匹配所有主机,并可用于允许一个用户从任何地方连接。一个空白的Host值等同于 % 。(例外:在db表中,一个空白 Host值含义是“进一步检查 host 表”,该过程在“查询访问验证”中介绍。)名师资料总结 - - -精品资料欢迎下载
10、 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 8 页 - - - - - - - - - 从MySQL 3.23起,你也可以指定带一个表明那些为用于网络地址的网络掩码的IP地址,如 192.168.128.0/17 指定一个17位网络地址并匹配其 IP地址是192.168.128 前17位的任何主机。User 用户名必须是文字的或空白。一个空白值匹配任何用户。% 作为一个 User值不意味着空白,相反它匹配一个字面上的 % 名字,这可能不是你想要的。当一个到来的连接通过 user表被验证而匹配的记录包含一个空
11、白的User值,客户被认为是一个匿名用户。 Password 口令值可以是空或非空,不允许用通配符。一个空口令不意味着匹配任何口令,它意味着用户必须不指定口令。口令以一个加密过的值存储,不是一个字面上的文本。如果你在Password列中存储一个照字面上的口令,用户将不能连接! GRANT语句和mysqladmin password命令为你自动加密口令,但是如果你用诸如INSERT 、REPLACE、UPDATE或SET PASSWORD等命令,一定要用 PASSWORD(new_password)而不是简单的 new_password来指定口令。 Db在columns_priv 和tables
12、_priv表中,Db 值必须是真正的数据库名(照字面上),不允许模式和空白。在db和host 中,Db 值可以以字面意义指定或使用SQL 模式字符 % 或 _ 指定一个通配符。一个 % 或空白匹配任何数据库。 Table_name ,Column_name这些列中的值必须是照字面意思的表或列名,不允许模式和空白。某些范围列被服务器视为大小写敏感的,其余不是。这些原则总结在下表中。特别注意Table_name 值总是被看作大小写敏感的,即使在查询中的表名的大小写敏感性对待视服务器运行的主机的文件系统而定(UNIX 下是大小写敏感,而 Windows 不是)。表3 授权表范围列的大小写敏感性 列H
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年数据库和表权限 2022 数据库 权限
限制150内