承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

怎么实现只授与用户查看存储进程定义的权限

管理员 2023-06-26 08:28:47 互联网圈 11 ℃ 0 评论 4196字 收藏

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

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

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

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

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

PRIVILEGE NAME PROPERTY

——— —————————————- ———-

⑴40 CREATE PROCEDURE 0

⑴41 CREATE ANY PROCEDURE 0

⑴42 ALTER ANY PROCEDURE 0

⑴43 DROP ANY PROCEDURE 0

⑴44 EXECUTE ANY PROCEDURE 0

⑵41 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权限给某个用户,就能够实现只授与用户查看存储进程定义的权限,而限制用户修改、履行存储进程。从而到达只授权用户查看存储进程定义的权限。不过这样实现,总让我感觉有点怪怪的。

本篇文章到此结束,如果您有相关技术方面疑问可以联系我们技术人员远程解决,感谢大家支持本站!

文章来源:丸子建站

文章标题:怎么实现只授与用户查看存储进程定义的权限

https://www.wanzijz.com/view/59309.html

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信