一、背景
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;