[MySQL] 存储过程、函数、触发器和视图的权限检查

来源:互联网 发布:华硕truelife软件 编辑:程序博客网 时间:2024/05/01 15:24

当存储过程、函数、触发器和视图创建后,不单单创建者要执行,其它用户也可能需要执行,换句话说,执行者有可能不是创建者本身,那么在执行存储过程时,MySQL是如何做权限检查的?

在默认情况下,MySQL将检查创建者的权限。假设用户A创建了存储过程p()访问表T,并把execute的权限赋给了B,即使用户B没有访问表T的权限,也能够通过执行存储过程p()访问表T。

下面看一个例子:

首先,我们创建一个表test.t和两个用户a,b,并把权限赋予用户a

[sql] view plaincopyprint?
  1. root@(none) 05:39:45>create table portal.t as select * from mysql.user;  
  2. Query OK, 25 rows affected (0.16 sec)  
  3. Records: 25  Duplicates: 0  Warnings: 0  
  4.   
  5. root@(none) 05:39:55>create user a identified by 'a';  
  6. Query OK, 0 rows affected (0.02 sec)  
  7.   
  8. root@(none) 05:40:51>create user b identified by 'b';  
  9. Query OK, 0 rows affected (0.00 sec)  
  10.   
  11. root@(none) 05:40:59>grant all privileges on portal.* to a;  
  12. Query OK, 0 rows affected (0.01 sec)  
接着,以用户a创建存储过程p():

[sql] view plaincopyprint?
  1. DELIMITER $$  
  2. USE portal$$  
  3. CREATE PROCEDURE `p`()  
  4. BEGIN  
  5.   SELECT COUNT(*) FROM portal.t;  
  6. END$$  
  7. DELIMITER ;  
并把执行该存储过程的权限赋给用户b:

[sql] view plaincopyprint?
  1. root@(none) 05:54:28>grant execute on procedure portal.p to b;  
  2. Query OK, 0 rows affected (0.00 sec)  
这时候,已用户b连接后通过执行存储过程可以获得t表的访问权限:

[sql] view plaincopyprint?
  1. b@(none) 05:58:20>call portal.p();  
  2. +----------+  
  3. COUNT(*) |  
  4. +----------+  
  5. |       25 |  
  6. +----------+  
  7. 1 row in set (0.00 sec)  
  8.   
  9. Query OK, 0 rows affected (0.00 sec)  
但如果直接访问将出现权限错误:

[sql] view plaincopyprint?
  1. b@(none) 05:58:40>select count(*) from portal.t;  
  2. ERROR 1142 (42000): SELECT command denied to user 'b'@'192.168.1.15' for table 't'  

MySQL这样的设置有一定的道理,但同时也带来了安全隐患:比如如果一个用户通过创建一个存储过程来访问敏感数据,则可以调用该存储过程的所有用户都能访问敏感数据。

如果你不想使用MySQL的默认设置,可以在定义存储程序和视图时在create语句里使用definer = account字句指定定义者,这样在执行存储程序和视图时,将检查definer的权限,而不是创建者的权限。

举个例子,当你用root 创建一个存储过程时,在默认情况下,在执行该存储过程时,执行者将获得root的权限,但当你加上definer = A后,执行者只能获得A的权限。

但是definer还是没能完全解决上面提到的安全隐患,别急,MySQL还提供了SQL SECURITY选项来控制权限,它有两个取值:

1)DEFINER:以定义者的权限执行(默认)

2)INVOKER:以调用者的权限执行

如果你不想在存储程序或试图在执行时的权限多于调用者,就设置SQL SECURITY INVOKER即可。

例如,下面的试图将访问mysql.user,并设置了SQL SECURITY INVOKER选项,这样如果调用者没有访问mysql.user的权限,则无法通过权限检查。

[sql] view plaincopyprint?
  1. create sql security invoker view v  
  2.   as select * from mysql.user;  
注意:因为触发器和事件是由系统调用的,没有调用者的概念,所以它们没有SQL SECURITY选项。
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 妻子要离婚丈夫不离怎么办 弟媳妇天天在家吵架怎么办 弟媳妇不和我说话怎么办 我想和弟媳妇做一次怎么办 老公对弟媳妇有非分之想怎么办 跟弟媳妇有矛盾怎么办 学生考试前不认真怎么办 有人雇凶要杀我怎么办 高考理综数学英语都没考好怎么办 母亲判刑孩子未成年无人监管怎么办 高三了数学30分怎么办 母猪发烧耳朵放血止不住了怎么办? 青春期孩子动手打父母该怎么办 20岁睡觉不老实怎么办 孕妇梦见钱掉了怎么办 小孩晚上睡觉鼻子塞怎么办 宝宝晚上睡觉鼻子塞怎么办 按摩后吹冷气发冷怎么办 碰到特别细心敏感的下属怎么办 睡觉压的肩膀疼怎么办 睡觉感觉被压住动弹不得怎么办 越想睡觉越睡不着怎么办 腿被裤子染黑了怎么办 肚子上的松皮怎么办 在公司天天背锅怎么办 职场老实背锅怎么办 三星a8充不了电怎么办 果6软件连不上网怎么办 孩子在幼儿园磕伤了怎么办 小孩在幼儿园摔骨折了怎么办 孩子在幼儿园摔骨折了怎么办 大腿被撞了很痛怎么办 马面褶子坏了怎么办 纱料衣服有褶怎么办 裙子如果后背那里小了怎么办 湖州耳朵鸣很严重怎么办 预授权撤销错了怎么办 打酒店里小卡片电话被骗怎么办 本科错过了选导师该怎么办 本科导师威胁学生不让毕业怎么办 意向导师名额满了怎么办?