Oracle 的 SEC_CASE_SENSITIVE_LOGON 参数

Oracle 的SEC_CASE_SENSITIVE_LOGON 参数

关键版本信息

SEC_CASE_SENSITIVE_LOGON 参数在以下版本中被弃用:

  1. Oracle 12c Release 1 (12.1)

    • 该参数首次被标记为"过时"(obsolete)
    • 但依然保持功能有效
  2. Oracle 18c/19c 及更高版本

    • 参数被完全弃用(deprecated)
    • 虽然仍能查询和设置,但不再影响数据库行为
    • 密码大小写敏感性变为强制启用且不可配置

版本行为对比表

Oracle 版本 参数状态 默认行为 是否可修改
10g及以下 有效 不区分大小写(FALSE)
11g 有效 区分大小写(TRUE)
12.1 过时(Obsolete) 区分大小写 是(但不建议)
12.2+ 弃用(Deprecated) 强制区分大小写
18c/19c/21c 弃用 强制区分大小写

官方文档说明

根据Oracle 19c安全指南:

"As of Oracle Database 12c Release 2, the SEC_CASE_SENSITIVE_LOGON parameter is deprecated. Case-sensitive passwords are always enforced and cannot be disabled."

迁移建议

  1. 升级到12c+的处理方案

    sql 复制代码
    -- 1. 检查现有密码兼容性
    SELECT username FROM dba_users 
    WHERE password_versions NOT LIKE '%12%';
    
    -- 2. 批量重置密码(如需)
    BEGIN
      FOR r IN (SELECT username FROM dba_users WHERE account_status='OPEN') LOOP
        EXECUTE IMMEDIATE 'ALTER USER '||r.username||' IDENTIFIED BY "NewPass123"';
      END LOOP;
    END;
  2. 应用适配要求

    • 确保所有连接字符串使用正确大小写
    • 更新硬编码密码的配置文件
    • 修改自动化的密码管理脚本

替代方案

在12.2+版本中,如需控制认证行为,应考虑:

  1. 使用统一目录服务

    sql 复制代码
    ALTER SYSTEM SET ldap_directory_access = 'PASSWORD';
  2. 配置全局认证模块

    sql 复制代码
    -- 使用Oracle Kerberos适配器
    ALTER SYSTEM SET os_authent_prefix = '' SCOPE=SPFILE;
  3. 实施代理认证

    sql 复制代码
    ALTER USER app_user GRANT CONNECT THROUGH proxy_user;

检查当前版本实际行为的方法

sql 复制代码
-- 方法1:测试密码敏感性(需实际尝试)
DECLARE
  v_count NUMBER;
BEGIN
  BEGIN
    EXECUTE IMMEDIATE 'CREATE USER testuser IDENTIFIED BY "Test123"';
    EXECUTE IMMEDIATE 'GRANT CREATE SESSION TO testuser';
    
    BEGIN
      EXECUTE IMMEDIATE 'CONNECT testuser/test123';
      DBMS_OUTPUT.PUT_LINE('Case-insensitive allowed (unexpected)');
    EXCEPTION
      WHEN OTHERS THEN 
        DBMS_OUTPUT.PUT_LINE('Case-sensitive enforced (expected)');
    END;
    
    EXECUTE IMMEDIATE 'DROP USER testuser';
  EXCEPTION
    WHEN OTHERS THEN 
      DBMS_OUTPUT.PUT_LINE('Setup failed: '||SQLERRM);
  END;
END;
/

-- 方法2:检查参数元数据(12c+)
SELECT name, isdeprecated, description 
FROM v$parameter 
WHERE name = 'sec_case_sensitive_logon';

在Oracle 12.2及更高版本中,即使显示参数存在,密码大小写敏感性也始终强制启用,这是Oracle加强安全体系的重要改进。

相关推荐
盒子691011 小时前
图生图大模型对于各种复杂的图片如何做负载均衡呢?
运维·负载均衡
鹏大师运维18 小时前
为什么信创电脑装软件总提示“软件包架构不匹配”?
linux·运维·架构·国产化·麒麟·deb·统信uos
007张三丰18 小时前
软件测试专栏(11/20):测试框架开发:pytest深度解析与插件体系
运维·服务器·自动化测试·pytest·测试框架
海南java第二人19 小时前
Nebula Graph 实战:基于图数据库存储 CMDB 实体关系
数据库·图数据库·nebula
weixin_6042366719 小时前
华三 路由器 极简核心配置
运维·服务器·网络·h3c·h3c路由器
曹牧19 小时前
oracle:“not all variables bound”
数据库·oracle
数据库百宝箱20 小时前
Oracle RMAN Image Copy 本地恢复
数据库·oracle
鹤落晴春20 小时前
【Linux复习】管理SELinux安全性
linux·运维·服务器
AI智图坊20 小时前
多件装组合SKU图的批量生产效率分析:从PS手工到AI自动化的工作流改造
大数据·运维·人工智能·gpt·ai作画·自动化·aigc
zuYM4g7Dp21 小时前
NoSql数据库设计心得
数据库·nosql