有关role的一点总结!

1、没有role完全可以控制权限的使用,只是不够灵活和方便,那么角色的作用到底是什么呢?这里简单的归结为2条:
1)实现权限的批量管理
2)动态控制权限
利用role实现权限的批量管理非常容易理解,这里不作更多的介绍;就role如何动态控制权限做一些简单的总结。
2、使role生效或者失效
SQL> create role rl1;
角色已创建。
--可以为role设置password,防止他人随意设置role
SQL> create role rl2 identified by rl2 ;
角色已创建。
SQL> select * from dba_role_privs where grantee='XYS';
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
XYS DBA NO YES
XYS RL1 YES YES
XYS RL2 YES YES
--可以动态的设置role使其失效,不过当把带口令的role设置为none时不要求输入password
SQL> set role none;
角色集
SQL> select * from dba_role_privs where grantee='XYS';
select * from dba_role_privs where grantee='XYS'
*
第 1 行出现错误:
ORA-00942: 表或视图不存在

SQL> create table t(id int);
create table t(id int)
*
第 1 行出现错误:
ORA-01031: 权限不足
--===================================
SQL> show user
USER 为 "XYS"
--当把带口令的role启用时需要输入口令
SQL> set role all;
set role all
*
第 1 行出现错误:
ORA-01979: 角色 'RL2' 的口令缺失或无效
--all可以和except结合使用,none不能和except结合使用
SQL> set role all except rl2;
角色集
SQL> select * from dba_role_privs where grantee='XYS';
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
XYS DBA NO YES
XYS RL1 YES YES
XYS RL2 YES YES
--但是all不能和identified by结合使用,这容易理解啊,all代表所有role,如果多个all存在password,那么显然不可能
让all和identified by来结合使用
SQL> set role all identified by rl2;
set role all identified by rl2
*
第 1 行出现错误:
ORA-00933: SQL 命令未正确结束
--如果role存在password的话只能一个一个的写了,每一个role后面都写上自己的identified by password
SQL> set role dba,rl1,rl2 identified by rl2;
角色集
--none不能和except结合使用
SQL> set role none except rl2;
set role none except rl2
*
第 1 行出现错误:
ORA-00933: SQL 命令未正确结束
SQL> set role all except rl2;
角色集
SQL> select * from session_roles;
ROLE
------------------------------
DBA
SELECT_CATALOG_ROLE
HS_ADMIN_ROLE
EXECUTE_CATALOG_ROLE
DELETE_CATALOG_ROLE
EXP_FULL_DATABASE
IMP_FULL_DATABASE
GATHER_SYSTEM_STATISTICS
SCHEDULER_ADMIN
WM_ADMIN_ROLE
RL1
ROLE
------------------------------
CONNECT
RESOURCE
已选择13行。
SQL> set role none;
角色集
--role失效之后,该session就没有了role所具有的所有权限,
但是用户xys通过其他窗口登录oracle时依然具有role的权限
SQL> select * from session_roles;
未选定行
SQL> show user
USER 为 "XYS"
SQL>
再开一个sqlplus窗口,建立其他session:
因为具有dba role,所以列出来的权限比较多
C:>sqlplus xys/manager
SQL*Plus: Release 10.2.0.1.0 - Production on 星期五 6月 27 14:11:01 2008
Copyright (c) 1982, 2005, Oracle. All rights reserved.

连接到:
Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
With the Partitioning, OLAP and Data Mining options
SQL> select * from session_privs;
PRIVILEGE
----------------------------------------
ALTER SYSTEM
AUDIT SYSTEM
CREATE SESSION
ALTER SESSION
RESTRICTED SESSION
CREATE TABLESPACE
ALTER TABLESPACE
MANAGE TABLESPACE
...................
READ ANY FILE GROUP
CHANGE NOTIFICATION
CREATE EXTERNAL JOB
已选择161行。
SQL>
3、使user的role失效或者生效
SQL> show user
USER 为 "XYS"
SQL> create user test identified by test;
用户已创建。
SQL> grant rl1,rl2 to test;
授权成功。
SQL> select * from dba_role_privs where grantee in ('RL1','RL2');
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
RL1 CONNECT NO YES
RL1 RESOURCE NO YES
SQL> connect test/test
已连接。
--不能创建表,没有使用表空间users的权限,说明unlimited tablespace
没有随着resource被授予role RL1而被授予RL1(因为unlimited tablespace不能被授予role)
,为什么?暂时不知道。不过unlimited tablespace是一个非常特殊的系统权限,unlimited tablespace可以随着resource
被授予用户而被授予用户,当然此时TEST也没有unlimited tablespace,所以无法创建表
权限
SQL> create table t(id int);
create table t(id int)
*
第 1 行出现错误:
ORA-01950: 对表空间 'USERS' 无权限

SQL> connect xys/manager
已连接。
--不能把系统权限unlimited tablespace授予role
SQL> grant unlimited tablespace to rl2;
grant unlimited tablespace to rl2
*
第 1 行出现错误:
ORA-01931: 无法将 UNLIMITED TABLESPACE 授予角色

SQL> grant unlimited tablespace to test;
授权成功。
SQL> select * from dba_role_privs where grantee='TEST';
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
TEST RL1 NO YES
TEST RL2 NO YES
SQL> select * from dba_sys_privs where grantee='TEST';
GRANTEE PRIVILEGE ADM
------------------------------ ---------------------------------------- ---
TEST UNLIMITED TABLESPACE NO
SQL> show user
USER 为 "XYS"
SQL> connect test/test
已连接。
SQL> create table t(id int);
表已创建。
SQL> connect xys/manager
已连接。
SQL> alter user test default role none;
用户已更改。
SQL> connect test/test
ERROR:
ORA-01045: 用户 TEST 没有 CREATE SESSION 权限; 登录被拒绝

警告: 您不再连接到 ORACLE。
SQL> connect xys/manager
已连接。
SQL> select * from dba_role_privs where grantee='TEST';
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
TEST RL1 NO NO
TEST RL2 NO NO
--此时为什么不需要输入rl2的口令?莫非是因为rl2是xys用户创建的?
其实不是,再来看看alter user xys的default role的效果,发现
通过alter user ...default role...也不需要输入口令,这里不知道
是否是orale的漏洞还是这样设计另有其他目的,不得而知,这样看来
通过这种方法可以跨过role的password!
SQL> alter user test default role all;
用户已更改。
SQL> alter user xys default role none;
用户已更改。
SQL> alter user xys default role all;
用户已更改。
SQL> set role none;
角色集
SQL> set role all;
set role all
*
第 1 行出现错误:
ORA-01979: 角色 'RL2' 的口令缺失或无效
--通过set role all就需要输入rl2的口令,而通过alter user ...
default role all就不需要输入口令!
SQL>
SQL> select * from dba_role_privs where grantee='TEST';
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
TEST RL1 NO YES
TEST RL2
NO YES
--同样none不能和except结合使用
SQL> alter user test default role none except rl2;
alter user test default role none except rl2
*
第 1 行出现错误:
ORA-00922: 选项缺失或无效

SQL> alter user test default role none;
用户已更改。
--all可以和except结合使用
SQL> alter user test default role all except rl2;
用户已更改。
SQL> select * from dba_role_privs where grantee='TEST';
GRANTEE GRANTED_ROLE ADM DEF
------------------------------ ------------------------------ --- ---
TEST RL1 NO YES
TEST RL2 NO NO
SQL>

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/751371/viewspace-604599/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/751371/viewspace-604599/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值