[ORACLE]oracle用户密码永不过期修改以及ORA-28000报错解决

一、背景

oracle11g之后的版本在账号安全上有一个新特性,类似系统账号过期一样。 创建用户时缺省密码过期限制是180天, 超过180天用户密码未做修改则该用户无法登录。

二、确认用户的密码策略

1.查看用户密码策略

sql>select t.USERNAME,t.password,t.ACCOUNT_STATUS,t.LOCK_DATE,t.EXPIRY_DATE,t.PROFILE from dba_users t;

2.查看指定概要文件(如default)的密码有效期设置:

sql>SELECT * FROM dba_profiles ;

这些参数的意义:
FAILED_LOGIN_ATTEMPTS 整数设定登录到Oracle 数据库时可以失败的次数。一旦某用户尝试登录数据库的达到该值时,该用户的帐户就被锁定,只能由DBA能解锁。
PASSWORD_LIFE_TIME 设定口令的有效时间(天数),一旦超过这一时间,必须重新设口令。缺省为UNLIMITED。
PASSWORD_REUSE_TIME 许多系统不许用户重新启用过去用过的口令。该资源项设定了一个失效口令要经过多少天,用户才可以重新使用该口令。缺省为UNLIMITED.
PASSWORD_REUSE_MAX 重新启用一个先前用过的口令前必须对该口令进行重新设置的次数(重复用的次数)。
PASSWORD_LOCK_TIME 设定帐户被锁定的天数(当登录失败达到FAILED_LOGIN_ATTEMPTS时)。
PASSWORD_GRACE_TIME 设定在口令失效前,给予的重新设该口令的宽限天。当口令失效之后回,在登录时会出现警告信息显示该天数。如果没有在宽限天内修改口令,口令将失效。
PASSWORD_VERITY_FUNCTION该资源项允许调用一个PL/SQL 来验证口令。Oracle公司已提供该应用 的脚本,但是只要愿意的话,用户可以制定自己的验证脚本。该参数的设定就是PL/SQL函数的名称。缺省为NULL.

3.后期可以使用如下语句

sql>SELECT * FROM dba_profiles s WHERE s.profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME';

该库的默认有效期是180天

三、修改用户密码策略为unlimited

---修改默认有效期天数为不限制

sql>alter profile default limit password_life_time unlimited;

四、验证当前用户的密码策略

sql>SELECT * FROM dba_profiles s WHERE s.profile='DEFAULT' AND resource_name='PASSWORD_LIFE_TIME';

参数已修改

sql>select t.USERNAME,t.password,t.ACCOUNT_STATUS,t.LOCK_DATE,t.EXPIRY_DATE,t.PROFILE from dba_users t;

账户状态为OPEN ,LOCKED的用户记录expiry_date字段为空,表示无过期日期

修改之后不需要重启动数据库,会立即生效。

五、ora-28000报错解决

1.使用EXPIRED状态的账户登录时会报错ora-28000,需要重置密码

sql>alter user user_name identified by 123;

2.状态为EXPIRED&LOCKED的账户需要执行密码重置和解锁

sql>alter user user_name identified by 123;

sql>alter user user_name account unlock;

3.状态为LOCKED的账户需要执行解锁

sql>alter user user_name account unlock;

相关推荐
一点事5 小时前
oracle:存储过程基础语法
数据库·oracle
tebukaopu1485 小时前
mysql distinct慢
数据库·mysql
步步为营DotNet5 小时前
深入理解IAsyncEnumerable:异步迭代的底层实现与应用优化
java·服务器·数据库
数据库学啊5 小时前
专业的国产时序数据库公司
数据库·时序数据库
黑客思维者6 小时前
突破 Python 多线程限制:GIL 问题的 4 种实战解法
服务器·数据库·python·gil
l1t6 小时前
利用Duckdb求解Advent of Code 2025第5题 自助餐厅
数据库·sql·mysql·算法·oracle·duckdb·advent of code
驾数者6 小时前
Flink SQL关联查询:双流Join与维表Join实战技巧
数据库·sql·flink
njsgcs6 小时前
solidworks 二次开发 获取样条曲线bcurve的控制点
数据库
一 乐6 小时前
智慧养老|基于springboot+小程序社区养老保障系统设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·后端·小程序