1、在java链接oracle12时出现java.sql.SQLException: ORA-28040: 没有匹配的验证协议,如下图所示:
2、出现以上问题是由于连接数据库驱动和oracle版本不一致造成的,可以通过下载新的驱动解决,也可以使用修改配置的方式,在Oracle的安装路径下找到sqlnet.ora文件,如下图所示:
3、在文件的最后添加如下配置:
SQLNET.ALLOWED_LOGON_VERSION=8 SQLNET.ALLOWED_LOGON_VERSION_SERVER=8 SQLNET.ALLOWED_LOGON_VERSION_CLIENT=8
如下图所示:
4、重启oracle数据库服务,主要是监听,不过最好都重启一下。
5、此时通过java连接出现
java.sql.SQLException: ORA-01017: 用户名/口令无效; 登录被拒绝
但是通过PLSQL Developer 13 (64 bit)和sqldeveloper又能正常连接。
6、解决办法就是重新修改用户的密码即可,通过如下命令登录到sysdba中:
sqlplus / as sysdba conn / as sysdba; alter user user1 identified by 123456;
7、如下图所示:
8、此时在次连接即可正常连接了。