本文主要是介绍ORA-28001: the password has expired 错误原因及解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
写在开头:
此次问题参考了博客:https://blog.csdn.net/btt2013/article/details/54862420, 并且使用了该博客中的三张图片附水印。
项目场景:
windows系统上运行tomcat跑的java项目,今天突然报错 the password has expired
问题描述:
只要涉及数据库操作就会报错
Caused by: java.sql.SQLException: ORA-28001: the password has expired
原因分析:
经过网上查询,得知是oracle 11g 的特性,密码是有180天的有效期的,过了有效期就需要重新修改密码,可能是为了安全性。
解决方案:
登录数据库服务器,使用 sqlplus / as sysdba命令,进入oracle数据库
使用:select * from dba_profiles where profile=‘DEFAULT’ and resource_name=‘PASSWORD_LIFE_TIME’; 语句查看密码的有效天数为180天,也就是六个月
使用: alter profile default limit password_life_time unlimited; 命令改为永久生效
设置之后还需要修改一次密码,否则还会出现password has expired异常
使用:alter user 用户名 identified by 密码; 修改密码。
如果用户锁定了需要使用:alter user 用户名 account unlock; 进行解锁
这篇关于ORA-28001: the password has expired 错误原因及解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!