mysql安全性指南(3)
作 者: 晏子
2.4 不用grant设置用户
如果你有一个早于3.22.11的mysql版本,你不能使用grant(或revoke)语句设置用户及其访问权限,但你可以直接修改授权表的内容。如果你理解grant语句如何修改授权表,这很容易。那么你通过手工发出insert语句就能自己做同样的事情。
当你发出一条grant语句时,你指定一个用户名和主机名,可能还有口令。对该用户生成一个user表记录,并且这些值记录在user、host和password列中。如果你在grant语句中指定全局权限,这些权限记录在记录的权限列中。其中要留神的是grant语句为你加密口令,而insert不是,你需要在insert中使用password()函数加密口令。
如果你指定数据库级权限,用户名和主机名被记录在db表的user和host列。你为其授权的数据库记录在db列中,你授予的权限记录在权限列中。
对于表级和列级权限,效果是类似的。在tables_priv和columns_priv表中创建记录以记录用户名、主机名和数据库,还有相关的表和列。授予的权限记录在权限列中。
如果你还记得前面的介绍,你应该能即使不用grant语句也能做grant做的事情。记住在你直接修改授权表时,你将通知服务器重载授权表,否则他不知道你的改变。你可以执行一个mysqladmin flush-privileges或mysqladmin reload命令强迫一个重载。如果你忘记做这个,你会疑惑为什么服务器不做你想做的事情。
下列grant语句创建一个拥有所有权的超级用户。包括授权给别人的能力:
grant all on *.* to anyname@localhost identified by passwd
with grant option
该语句将在user表中为anyname@localhost创建一个记录,打开所有权限,因为这里是超级用户(全局)权限存储的地方,要用insert语句做同样的事情,语句是:
insert into user values(localhost,anyname,password(passwd),
y,y,y,y,y,y,y,y,y,y,y,y,y,y)
你可能发现它不工作,这要看你的mysql版本。授权表的结构已经改变而且你在你的user表可能没有14个权限列。用show columns找出你的授权表包含的每个权限列,相应地调整你的insert语句。 下列grant语句也创建一个拥有超级用户身份的用户,但是只有一个单个的权限:
grant reload on *.* to flush@localhost identified by flushpass
本例的insert语句比前一个简单,它很容易列出列名并只指定一个权限列。所有其它列将设置为缺省的n:
insert into user (host,password,reload) values(localhost,flush,password(flushpass),y)
数据库级权限用一个on db_name.*子句而不是on *.*进行授权:
grant all on sample.* to boris@localhost identified by ruby
这些权限不是全局的,所以它们不存储在user表中,我们仍然需要在user表中创建一条记录(使得用户能连接),但我们也需要创建一个db表记录记录数据库集权限:
insert into user (host,user,password) values(localhost,boris,password(ruby))
insert into db values(localhost,sample_db,boris,y,y,y,y,y,y,n,y,y,y)
n列是为grant权限;对末尾的一个数据库级具有with grant option的grant语句,你要设置该列为y。
要设置表级或列级权限,你对tables_priv或columns_priv使用insert语句。当然,如果你没有grant语句,你将没有这些表,因为它们在mysql中同时出现。如果你确实有这些表并且为了某些原因想要手工操作它们,要知道你不能用单独的列启用权限。
你设置tables_priv.table_priv或columns_priv.column_priv列来设置包含你想启用的权限值。例如,要对一个表启用select和insert权限,你要在相关的tables_priv的记录中设置table_priv为select,insert。
如果你想对一个拥有mysql账号的用户修改权限,使用update而不是insert,不管你增加或撤销权限都是这样。要完全删除一个用户,从用户使用的每个表中删除记录。
如果你愿意避免发一个查询来直接修改全权表,你可以看一下mysql自带的mysqlaccess和mysql_setpermissions脚本。