其实简单点就是检查一下你的机器有没有一个ora_dba用户组,而且你登陆os的用户是否在这个组里,有的话问题的原因就找到了,下面是转的高手的介绍

本文环境配置:Oracle10gR2,Windows XP

Oracle的用户信息一般来说是保存在数据字典里的,所以常规用户在Oracle数据库没有启动的时候是无法登陆的。但有两类用户例外,这就是具有sysdba或者sysoper权限的用户。Oracle sysdba或者sysoper用户的登陆有两种方式:一是通过OS认证,二是通过密码文件验证。

究竟使用哪一种验证方式以及能否成功登陆取决于三个方面的因素:

1. sqlnet.ora中SQLNET.AUTHENTICATION_SERVICES的设置

2. 参数文件中REMOTE_LOGIN_PASSWORDFILE的设置

3. 密码文件 PWD%sid%.ora

Oracle进行权限验证的大致顺序如下:

1. 根据SQLNET.AUTHENTICATION_SERVICES的值决定是进行os验证还是密码文件验证。

2. 如果是os验证,根据当前用户的用户组判断是否具有sysdba权限。如果os验证失败,则进行密码文件验证。

2. 如果是密码文件验证,REMOTE_LOGIN_PASSWORDFILE的值以及密码文件是否存在决定了验证是否成功。

1. OS  

要启用os验证,就必须在qlnet.ora中设置SQLNET.AUTHENTICATION_SERVICES=(NTS),然后在Windows中建立ora_dba用户组,把相关用户加入到这个组中(e.g., administrator),这样administrator就可以在不用提供用户名和密码(或者提供任意的用户名和密码)的情况下以sysdba身份本地登陆。因为操作系统已经代替Oracle进行了验证。

测试一:ora_dba用户本地登陆

  1. C:/>sqlplus / as sysdba
  2. Connected to:
  3. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  4. With the OLAP and Data Mining options
  5. SQL>
  6. C:/>sqlplus wrong_user/wrong_password as sysdba
  7. Connected to:
  8. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  9. With the OLAP and Data Mining options
  10. SQL>
  1. C:/>sqlplus / as sysdba
  2. Connected to:
  3. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  4. With the OLAP and Data Mining options
  5. SQL>
  6. C:/>sqlplus wrong_user/wrong_password as sysdba
  7. Connected to:
  8. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  9. With the OLAP and Data Mining options
  10. SQL>

测试二:非ora_dba用户本地登陆

  1. C:/>sqlplus / as sysdba
  2. ERROR:
  3. ORA-01031: insufficient privileges
  4. Enter user-name:
  5. C:/>sqlplus wrong_user/wrong_password sysdba
  6. ERROR:
  7. ORA-01017: invalid username/password; logon denied
  8. Enter user-name:
  9. C:/>sqlplus sys/change_on_install as sysdba
  10. Connected to:
  11. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  12. With the OLAP and Data Mining options
  13. SQL>
  1. C:/>sqlplus / as sysdba
  2. ERROR:
  3. ORA-01031: insufficient privileges
  4. Enter user-name:
  5. C:/>sqlplus wrong_user/wrong_password sysdba
  6. ERROR:
  7. ORA-01017: invalid username/password; logon denied
  8. Enter user-name:
  9. C:/>sqlplus sys/change_on_install as sysdba
  10. Connected to:
  11. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  12. With the OLAP and Data Mining options
  13. SQL>

2. 密码文件验证

密码文件包含了被授予sysdba和sysoper权限的用户的用户名和密码。这是一个加密文件,一般来说存放在%oracle_home%/database目录下,文件名为PWD%sid%.ora。

如果要使用密码文件验证,则把sqlnet.ora改为SQLNET.AUTHENTICATION_SERVICES=none,或者从sqlnet.ora中删除SQLNET.AUTHENTICATION_SERVICES。同上匿名登陆sqlplus会失败,给出用户名和密码就可以成功登陆。

  1. C:/>sqlplus / as sysdba
  2. ERROR:
  3. ORA-01031: insufficient privileges
  4. Enter user-name:
  5. C:/>sqlplus sys/change_on_install as sysdba
  6. Connected to an idle instance.
  7. idle>
  1. C:/>sqlplus / as sysdba
  2. ERROR:
  3. ORA-01031: insufficient privileges
  4. Enter user-name:
  5. C:/>sqlplus sys/change_on_install as sysdba
  6. Connected to an idle instance.
  7. idle>

测试一:删除密码文件。使用用户名和密码登陆,失败!

  1. C:/>sqlplus sys/change_on_install as sysdba
  2. ERROR:
  3. ORA-01031: insufficient privileges
  4. Enter user-name:
  1. C:/>sqlplus sys/change_on_install as sysdba
  2. ERROR:
  3. ORA-01031: insufficient privileges
  4. Enter user-name:

测试二:恢复密码文件,设置REMOTE_LOGIN_PASSWORDFILE=none。使用用户名和密码登陆,失败!

  1. SQL> alter system set remote_login_passwordfile=none scope=spfile;
  2. System altered.
  3. C:/>sqlplus sys/change_on_install as sysdba
  4. ERROR:
  5. ORA-01017: invalid username/password; logon denied
  6. Enter user-name:
  1. SQL> alter system set remote_login_passwordfile=none scope=spfile;
  2. System altered.
  3. C:/>sqlplus sys/change_on_install as sysdba
  4. ERROR:
  5. ORA-01017: invalid username/password; logon denied
  6. Enter user-name:

测试三:恢复密码文件,设置REMOTE_LOGIN_PASSWORDFILE为EXCLUSIVE或者SHARED。使用用户名和密码登陆,成功!

  1. SQL> alter system set remote_login_passwordfile=exclusive scope=spfile;
  2. System altered.
  3. C:/>sqlplus sys/change_on_install as sysdba
  4. Connected to an idle instance.
  5. SQL>
  1. SQL> alter system set remote_login_passwordfile=exclusive scope=spfile;
  2. System altered.
  3. C:/>sqlplus sys/change_on_install as sysdba
  4. Connected to an idle instance.
  5. SQL>

3. 密码文件

查看具有sysdba或者sysoper权限的用户:

  1. SQL> select * from v$pwfile_users;
  2. USERNAME                        SYSDB    SYSOP
  3. ------------------------------  -------  -------
  4. SYS                             TRUE     TRUE
  1. SQL> select * from v$pwfile_users;
  2. USERNAME                        SYSDB    SYSOP
  3. ------------------------------  -------  -------
  4. SYS                             TRUE     TRUE

每次使用grant sysdba/sysoper授予新用户特殊权限或是alter user命令修改拥有sysdba/sysoper权限的用户密码的时候,Oracle都会自动的同步密码文件,这样保证在数据库没有打开的情况拥有特殊权限的用户能正常的登陆数据库以进行管理操作。

  1. SQL> grant sysdba to logicgate;
  2. Grant succeeded.
  3. SQL> select * from v$pwfile_users;
  4. USERNAME                       SYSDB     SYSOP
  5. ------------------------------- -------- --------
  6. SYS                             TRUE     TRUE
  7. LOGICGATE                       TRUE     FALSE
  1. SQL> grant sysdba to logicgate;
  2. Grant succeeded.
  3. SQL> select * from v$pwfile_users;
  4. USERNAME                       SYSDB     SYSOP
  5. ------------------------------- -------- --------
  6. SYS                             TRUE     TRUE
  7. LOGICGATE                       TRUE     FALSE

使用orapwd命令可以重建密码文件。

  1. C:/>orapwd
  2. Usage: orapwd file=<fname> password=<password> entries=<users> force=<y/n>
  3. where
  4. file - name of password file (mandatory),
  5. password - password for SYS (mandatory),
  6. entries - maximum number of distinct DBA (optional),
  7. force - whether to overwrite existing file (optional)
  1. C:/>orapwd
  2. Usage: orapwd file=<fname> password=<password> entries=<users> force=<y/n>
  3. where
  4. file - name of password file (mandatory),
  5. password - password for SYS (mandatory),
  6. entries - maximum number of distinct DBA (optional),
  7. force - whether to overwrite existing file (optional)

其中文件名和密码是必需的。entries设置了密码文件可包含的dba用户的最大数目。force定义了是否覆盖当前文件。重建密码文件会清除系统内除了sys用户以外所有sysdba用户的密码。必须使用grant sysdba同步密码文件。

  1. C:/>orapwd file=%oracle_home%/database/PWDepcit.ora password=temp entries=20 force=y;
  2. C:/>sqlplus sys/temp as sysdba
  3. Connected to:
  4. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  5. With the OLAP and Data Mining options
  6. SQL> select * from v$pwfile_users;
  7. USERNAME                        SYSDB    SYSOP
  8. ------------------------------- -------- --------
  9. SYS                             TRUE     TRUE
  1. C:/>orapwd file=%oracle_home%/database/PWDepcit.ora password=temp entries=20 force=y;
  2. C:/>sqlplus sys/temp as sysdba
  3. Connected to:
  4. Oracle Database 10g Enterprise Edition Release 10.2.0.1.0 - Production
  5. With the OLAP and Data Mining options
  6. SQL> select * from v$pwfile_users;
  7. USERNAME                        SYSDB    SYSOP
  8. ------------------------------- -------- --------
  9. SYS                             TRUE     TRUE

【转载】为什么任何随便输入的账号使用SYSDBA权限都能登陆oracle的更多相关文章

  1. 【转载】 C#检测输入的内容中是否含有中文

    在C#开发中,可以结合正则表达式,来检测输入的内容中是否包含中文,Regex类是C#中有关正则表达式处理的相关类,功能强大,我们只需要设置好规则,即可很快检测出输入的字符串内容中是否含有中文信息. R ...

  2. 【转载】MySql新建账号并分配权限

    在服务器的MySQL运维过程中,我们有时会遇到新建MySql账号的情况,要求新建的账号只允许某些特定的数据库操作权限,只能访问到特定的数据库,实现数据库权限的严格管理,以下以MySQL-Front管理 ...

  3. 转载——分享一个html+js+ashx+easyui+ado.net权限管理系统

    EasyUI.权限管理 这是个都快被搞烂了的组合,但是easyui的确好用,权限管理在项目中的确实用.一直以来博客园里也不少朋友分享过,但是感觉好的要不没源码,要不就是过度设计写的太复杂看不懂,也懒得 ...

  4. CentOS学习笔记--账号管理与权限配置

    Linux 的账号管理与权限配置 管理员的工作中,相当重要的一环就是『管理账号』啦! 使用者标识符: UID 与 GID 虽然我们登陆 Linux 主机的时候,输入的是我们的账号,但是其实 Linux ...

  5. mysql创建账号及管理权限

    mysql创建账号及管理权限 0.mysql版本8.0.15,服务器版本:RHEL 6.5 1.创建用户名密码 mysql> use mysql; mysql> create user ' ...

  6. CentOS7安装及配置vsftpd (FTP服务器FTP账号创建以及权限设置)

    本文章向大家介绍CentOS7安装及配置vsftpd (FTP服务器FTP账号创建以及权限设置),主要包括CentOS7安装及配置vsftpd (FTP服务器FTP账号创建以及权限设置)使用实例.应用 ...

  7. 解决升级WordPress及插件需输入FTP账号的问题

    当添加,删除,升级 WordPress 插件或者直接升级 WordPress 的时候,WordPress 总是提示让你输入 FTP 帐号信息,非些烦人. 我们可以在 wp-config.php 中定义 ...

  8. git托管代码随笔--运用ssh传输,不用每次提交频繁输入github账号密码

    遇到问题:在使用git bash的时候 每次git push均要输入账号密码. 问题原因:使用的是http传输,需用ssh传输. 解决方法: 1.设置密钥 ssh-keygen -t rsa -C & ...

  9. (转载):() { :|:& }; : # <-- 打开终端,输入这个,回车.你看到了什么??

    代码::() { :|:& }; : 为什么这个东西会让你的系统死掉???有人执行了然后问我 让我们来分析一下这段代码,我改一下格式,但内容是一样的 代码::() # 定义一个叫“:”的过程  ...

随机推荐

  1. Python基础之列表及元组的增删改查

    定义一个列表 晚上的状态不太适合写博客,容易犯困~ 列表的增加有三种方式 第一种主流的增加 append函数 list1 = ['noevil', 'fordearme', 'city', 'cust ...

  2. leetcode 中等题(2)

    50. Pow(x, n) (中等) double myPow(double x, int n) { ; unsigned long long p; ) { p = -n; x = / x; } el ...

  3. python基础入门学习2

    python 整体注释:选中所有然后CTRL+? 运算符 + - * /   **  %  // 布尔值 true 真  False 假 !=不等于 <>不等于 算数运算,赋值运算,比较运 ...

  4. CentOS 查看是否安装软件包

    1. rpm包安装的,可以用rpm -qa看到,如果要查找某软件包是否安装,用 rpm -qa | grep "软件或者包的名字" 2. deb包安装的,可以用dpkg -l能看到 ...

  5. NumPy 矩阵库(Matrix)

    NumPy 矩阵库(Matrix) NumPy 中包含了一个矩阵库 numpy.matlib,该模块中的函数返回的是一个矩阵,而不是 ndarray 对象. 一个 的矩阵是一个由行(row)列(col ...

  6. Jenkins安装部署(二)

    Jenkins配置 一.修改jenkins家目录 由于jenkins在启动个之后会默认将所有的构建应用在家目录中创建一遍,为了合理化服务器资源,重新定义jenkins家目录. 在tomcat的cata ...

  7. vue 打包

    1.assetsPublicPath路径改为‘./’(两处) 2.cmd运行  cnpm run build 3.生成的dist文件即可本地访问

  8. 489. Robot Room Cleaner扫地机器人

    [抄题]: Given a robot cleaner in a room modeled as a grid. Each cell in the grid can be empty or block ...

  9. 24-算法训练 删除数组零元素-- list的使用

    http://lx.lanqiao.cn/problem.page?gpid=T201 算法训练 删除数组零元素   时间限制:1.0s   内存限制:512.0MB      从键盘读入n个整数放入 ...

  10. 修复python命令行下接收不到参数的问题

    由于之前安装过多个python版本,导致出现了在命令行下直接给py文件传递参数的时候接收不到,即使重新卸载安装也没有解决. 解决办法: 修改如下图路径下的键值为:"D:\Python27\p ...