oracle 11g密码长度和复杂度查看与设置

verify_function_11G 的密码复杂性要求:

密码长度至少为 8 个字符。

密码必须包含至少一个数字和一个字母字符。

密码不能与用户名相同或相似。

密码不能是服务器名或其变体。

密码不能是常见的弱密码(如 welcome1、oracle123 等)。

注意事项:

默认配置:在创建数据库时,PASSWORD_VERIFY_FUNCTION 参数的默认值为 NULL,即不启用任何密码验证函数。

安全性:为了增强数据库的安全性,建议启用 verify_function_11G 函数,并根据实际需求调整密码策略。

兼容性:如果数据库需要与其他系统集成,确保密码策略的兼容性,避免因密码复杂性要求过高而导致用户无法登录。

查看当前的密码复杂度设置

SELECT * FROM dba_profiles WHERE resource_name = 'PASSWORD_VERIFY_FUNCTION';

LIMIT表示分配给该 PROFILE 的密码验证函数名称。如果为 NULL,表示未设置密码验证函数。

#查看是否有相关密码验证函数

select object_name from dba_objects where upper(object_name) like '%VERIFY_FUNCTION%';

结果为空,则说明没有相关函数,需要进行相关设置。

二 设置密码复杂度

Oracle 11g 自带密码验证函数verify_function_11G。

通过运行 $ORACLE_HOME/rdbms/admin/utlpwdmg.sql 脚本可以创建及启用该函数。

该脚本会创建 verify_function 和 verify_function_11G 两个函数。

再设置配置文件,绑定该函数即可。

2.1 运行utlpwdmg.sql

@?/rdbms/admin/utlpwdmg.sql

2.2 查看是否有相关密码验证函数

select object_name from dba_objects where upper(object_name) like '%VERIFY_FUNCTION%';

可以看到自动生成了两个密码验证函数。

2.3 再次查看密码复杂度设置

SELECT * FROM dba_profiles WHERE resource_name = 'PASSWORD_VERIFY_FUNCTION';

发现密码复杂函数自动绑定到了DEFAULT的这个配置文件。

且账号过期及登录失败次数的设置也自动给更新了(我之前是unlimited,发现被分别自动更新为了180和10):

我这里不想让账号过期,也不想限制登录失败次数,这里将其还原为unlimited:

ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;

ALTER PROFILE DEFAULT LIMIT FAILED_LOGIN_ATTEMPTS UNLIMITED;

设置完密码复杂度后,对于新建的账号,需要满足密码复杂度的要求,不影响已建的弱口令账号的正常登录及使用,但若修改老用户的密码,也需要满足密码复杂度要求。

相关推荐
尤物程序猿1 小时前
【2025最新】为什么用ElasticSearch?和传统数据库MySQL与什么区别?
数据库·mysql·elasticsearch
别来无恙1491 小时前
MySQL JOIN详解:掌握数据关联的核心技能
数据库·mysql
小小不董1 小时前
Oracle OCP认证考试考点详解083系列06
linux·数据库·oracle·dba
一 乐2 小时前
宿舍报修|宿舍报修小程序|基于Java微信小程序的宿舍报修系统的设计与实现(源码+数据库+文档)
java·数据库·微信小程序·小程序·论文·毕设·宿舍报修小程序
CodeJourney.3 小时前
基于DeepSeek与HTML的可视化图表创新研究
数据库·人工智能·信息可视化·excel
kngines4 小时前
【PostgreSQL数据分析实战:从数据清洗到可视化全流程】3.3 异常值识别(Z-score法/IQR法/业务规则法)
数据库·postgresql·数据分析·z-score法·iqr法·业务规则法
王嘉俊9254 小时前
一条 SQL 查询语句是如何执行的(MySQL)
数据库·sql·mysql
cooldream20094 小时前
深入理解 Redis 的主从、哨兵与集群架构
数据库·redis·架构·系统架构师
blackA_4 小时前
数据库MySQL学习——day8(复习与巩固基础知识)
数据库·学习·mysql
magic 2455 小时前
SpringMVC——第三章:获取请求数据
java·数据库·springmvc