如何实现只授予用户查看存储过程定义的权限

有个网友问我,如何授予某个用户只能查看某些存储过程的定义权限,而不能让用户去修改、执行存储过程。看似简单的问题,却因为从没有碰到这样的需求。花了点时间才梳理、总结清楚。

关于oracle账号的权限问题,一般分为两种权限:

系统权限: 允许用户执行特定的数据库动作,如创建表、创建索引、创建存储过程等

对象权限: 允许用户操纵一些特定的对象,如读取视图,可更新某些列、执行存储过程等

像这种查看存储过程定义的权限为对象权限,但是我们还是首先来看看关于存储过程的系统权限吧:

privilege name          property 
 
--------- ---------------------------------------- ---------- 
 
  -140 create procedure         0 
 
  -141 create any procedure        0 
 
  -142 alter any procedure        0 
 
  -143 drop any procedure        0 
 
  -144 execute any procedure        0 
 
  -241 debug any procedure        0 

如上所示,关于存储过程的系统权限一般有六种: create procedure、create any procedure、 alter any procedure、drop any procedure、 execute any procedure、debug any procedure. 那么关于存储过程的对象权限又有那些呢? 如下例子所示,在用户escmuser下创建存储过程proc_test

create or replace procedure escmuser.proc_test 
 
as 
 
begin 
 
 dbms_output.put_line('it is only test'); 
 
end; 

使用system用户创建用户temp,如下所示

sql> create user temp identified by temp; 
 
user created. 
 
sql> grant connect,resource to temp; 
 
grant succeeded. 

在用户escmuser下将存储过程proc_test的所有权限授予给用户temp。 那么我们发现存储过程的对象权限只有execute、debug权限

sql> col grantee for a12; 
 
sql> col table_name for a30; 
 
sql> col grantor for a12; 
 
sql> col privilege for a8; 
 
sql> select * from user_tab_privs_made where grantee='temp'; 
 
 
grantee  table_name    grantor  privilege    gra hie 
 
---------- --------------------- ------------ --------------------------- --- --- 
 
temp   proc_test    escmuser  debug     no no 
 
temp   proc_test    escmuser  execute     no no 
 
 
sql> 

 

将存储过程porc_test的权限从temp用户收回,然后授予用户temp关于存储过程proc_test的debug权限

sql>revoke all on proc_test from temp; 
 
sql>grant debug on proc_test to temp; 

那么temp用户此时执行存储过程报权限不足

sql> set serverout on; 
 
sql> exec escmuser.proc_test; 
 
begin escmuser.proc_test; end; 
 
ora-06550: line 2, column 16: 
 
pls-00904: insufficient privilege to access object escmuser.proc_test 
 
ora-06550: line 2, column 7: 
 
pl/sql: statement ignored 

此时,如果修改存储过程proc_test就会ora-01031权限不足问题。但是你可以在pl/sql developer工具或使用下面视图查看存储过程的定义。如下所示。

select * from all_source where name='proc_test'

所以,只需要授予存储过程的debug权限给某个用户,就可以实现只授予用户查看存储过程定义的权限,而限制用户修改、执行存储过程。从而达到只授权用户查看存储过程定义的权限。不过这样实现,总让我感觉有点怪怪的。

以上就是www.887551.com为大家整理的如何实现只授予用户查看存储过程定义的权限,希望可以对大家的学习能有所帮助。

(0)
上一篇 2022年3月22日
下一篇 2022年3月22日

相关推荐