写在开头:
此次问题参考了博客: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; 进行解锁

当在Windows上的Tomcat Java项目中遇到ORA-28001错误时,这表明Oracle11g的数据库密码已过期。解决此问题需要登录数据库服务器,使用sqlplus/assysdba命令,查看并修改默认配置的密码有效天数,将其设置为无限期。然后,更新用户密码,并在必要时解锁账户。具体步骤包括查询密码有效期、修改默认配置、更改用户密码和解锁账户。
1868

被折叠的 条评论
为什么被折叠?



