li
  当前位置:主页 > 配置管理 > 文章内容
li
oracle os认证以及口令文件的一点总结!
来源: www.ixdba.net  作者: IXDBA.NET官方    时间:2008-03-11   阅读:40  
本文章共11519字,分8页,当前第1页,快速翻页:
 

讲课时的一些简单总结,欢迎一起讨论和指正!
可能还会不停的补充、增加一些内容!包括外部认证(其实也是os认证)以及client端os认证
1、os认证
oracle安装之后默认情况下是启用了os认证的,这里提到的os认证是指服务器端os认证。os认证的意思把登录数据库的用户和口令校验放在了操作系统一级。如果以安装oracle时的用户登录os,那么此时在登录oracle数据库时不需要任何验证,如:

SQL> connect /as sysdba
已连接。
SQL> connect
sys/aaa@dmt as sysdba
已连接。
SQL> connect sys/bbb as sysdba
已连接。
SQL> connect aaa/bbb as sysdba
已连接。
SQL> show user
USER 为 "SYS"
SQL>

不论输入什么用户(哪怕这个用户如aaa在数据库中根本不存在),只要以sysdba权限连接数据库,都可以连接上,并且连接用户是sys,这样很方便,有时候,如果忘记了数据库的密码,而又想登录数据库,可以通过这种方式,前提是在数据库服务器上;但是方便的同时也带来了一些安全隐患,于是很多人想屏蔽os认证,在win下只要把oracle_home/NETWORK/admin/sqlnet.ora中的SQLNET.AUTHENTICATION_SERVICES= (nts)nts改成none或者注释掉这句话(在前面加上#),就可以屏蔽os功能,要想以sys用户连上数据库必须输入正确的sys口令,如:

SQL> connect /as sysdba
ERROR:
ORA-01031: 权限不足


SQL> connect sys/aaa as sysdba
ERROR:
ORA-01017: 用户名/口令无效; 登录被拒绝


SQL> connect aaa/bbb as sysdba
ERROR:
ORA-01031: 权限不足


SQL> connect sys/system as sysdba
已连接。
SQL>

或者可以把oracle的安装用户从组ora_dba中删除掉,当然也可以直接把ora_dba这个组也删除,都可以屏蔽os功能。在unix/linux下也可以在文件sqlnet.ora中增加SQLNET.AUTHENTICATION_SERVICES=(none)以及删除dba(groupdel dba)组或者把oracle用户从dba组中删除都可以屏蔽os认证。利用这两种方法屏蔽os功能似乎总有些让人不放心,或者说不能让人完全信服,因为毕竟系统管理员还是可以创建ora_dba or dba组以及修改sqlnet.ora文件,如何彻底屏蔽os功能?让它"永世不得翻身"呢?我没有这方面的经验,大家可以补充!

2、口令文件

oracle的口令文件的作用是存放所有以sysdba或者sysoper权限连接数据库的用户的口令,如果想以sysdba权限远程连接数据库,必须使用口令文件,否则不能连上,由于sys用户在连接数据库时必须以sysdba or sysoper方式,也就是说sys用户要想连接数据库必须使用口令文件,因此我认为在数据库中存放sys用户的口令其实没有任何意义!使用口令文件的好处是即使数据库不处于open状态,依然可以通过口令文件验证来连接数据库。开始安装完oracle,没有给普通用户授予sysdba权限,口令文件中只存放了sys的口令,如果之后把sysdba权限授予了普通用户,那么此时会把普通用户的口令从数据库中读到口令文件中保存下来,当然这时必须要求数据库处于open状态。如:

SQL> grant sysdba to test;

授权成功。

SQL> connect test/aaa@orcl as sysdba
ERROR:
ORA-01017: 用户名/口令无效; 登录被拒绝


警告: 您不再连接到 ORACLE。
SQL> connect
test/test@orcl as sysdba
已连接。

SQL> alter database close;

数据库已更改。

SQL> grant sysdba , sysoper to test;
IXDBA.NET技术社区
grant sysdba , sysoper to test
*
第 1 行出现错误:
ORA-01109: 数据库未打开

到底有几个用户被授予了sysdba或者sysoper权限,可以通过查询如下v$pwfile_users获得,v$pwfile_users的信息就是源于口令文件的(This view lists users who have been granted SYSDBA and SYSOPER privileges as derived from the password file.)

SQL> select * from v$pwfile_users;



阅读更多内容1 · 2 · 3 · 4 · 5 · 6 · 7 · 8 · 下一页>>


  上一篇: oracle数据库9i升级到oracle10g方...   下一篇: alter system switch logfile 和...
li
 §相关评论  
 热点文章

·oracle Logfile的不同状态说明
·Oracle数据库的一些常用操作经
·Oracle10g(10.2) 在Redhat AS4
·oracle工具:浅谈LogMiner的使用
·RHAD AS4 上安装 Oracle 数据库
·oracle基础知识(物理结构)
·oracle基础:Oracle中null的使用
·Oracle常用基本语法操作集锦
·oracle数据库查询前台正在发出
·AIX+ORACLE10G安装手册
·oracle数据库9i升级到oracle10
li
 编辑推荐
·oracle Logfile的不同状态说明
·Oracle数据库的一些常用操作经
·Oracle10g(10.2) 在Redhat AS4
·oracle工具:浅谈LogMiner的使用
·RHAD AS4 上安装 Oracle 数据库
·oracle基础知识(物理结构)
·oracle基础:Oracle中null的使用
·Oracle常用基本语法操作集锦
·oracle数据库查询前台正在发出
·AIX+ORACLE10G安装手册
·oracle数据库9i升级到oracle10
li
 相关篇章
·oracle数据库9i升级到oracle10g方...
·AIX+ORACLE10G安装手册
·oracle数据库查询前台正在发出的...
·Oracle常用基本语法操作集锦
·oracle基础:Oracle中null的使用详...
·oracle基础知识(物理结构)
·RHAD AS4 上安装 Oracle 数据库 ...
·oracle工具:浅谈LogMiner的使用
·Oracle10g(10.2) 在Redhat AS4u2...
·Oracle数据库的一些常用操作经验...
·alter system switch logfile 和...
·Redhat enterprise linux 4环境下...
·linux下oracle 10g 自动启动配置...
·oracle Database 10g for Window...
·oracle asm安装配置
·利用EXP/IMP进行数据迁移,如何转...
·利用EXP/IMP进行数据迁移,如何转...
·ORA-00844: Parameter not takin...
·表空间、数据文件和控制文件——...
·基于裸设备的在linux下建立oracl...
 
li
设为首页 | 关于我们 | 技术服务 | 收藏本站 | 网站地图 | 联系方式 | 本站友情连接