java.sql.SQLException: ORA-28040: 没有匹配的验证协议(odbc6.jar,数据库用的是orcal12)

1、在java链接oracle12时出现java.sql.SQLException: ORA-28040: 没有匹配的验证协议,如下图所示:

java.sql.SQLException: ORA-28040: 没有匹配的验证协议(odbc6.jar,数据库用的是orcal12)

 

 

2、出现以上问题是由于连接数据库驱动和oracle版本不一致造成的,可以通过下载新的驱动解决,也可以使用修改配置的方式,在Oracle的安装路径下找到sqlnet.ora文件,如下图所示:

 java.sql.SQLException: ORA-28040: 没有匹配的验证协议(odbc6.jar,数据库用的是orcal12)

 

 3、在文件的最后添加如下配置:

SQLNET.ALLOWED_LOGON_VERSION=8
 
SQLNET.ALLOWED_LOGON_VERSION_SERVER=8
 
SQLNET.ALLOWED_LOGON_VERSION_CLIENT=8

  如下图所示:

java.sql.SQLException: ORA-28040: 没有匹配的验证协议(odbc6.jar,数据库用的是orcal12)

 

 

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、如下图所示:

java.sql.SQLException: ORA-28040: 没有匹配的验证协议(odbc6.jar,数据库用的是orcal12)

 

 8、此时在次连接即可正常连接了。

 

上一篇:Mybatis连接数据库时,常见的启动报错收集


下一篇:MySQL8.0 Public Key Retrieval is not allowed