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

2021/6/27 19:22:24

本文主要是介绍java.sql.SQLException: ORA-28040: 没有匹配的验证协议(odbc6.jar,数据库用的是orcal12),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

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、此时在次连接即可正常连接了。

 



这篇关于java.sql.SQLException: ORA-28040: 没有匹配的验证协议(odbc6.jar,数据库用的是orcal12)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程