Android - Oracle 12c 数据库连接问题 : java. sql.SQLException: ORA-28040: 没有匹配的身份验证协议(protocol)

标签 android oracle oracle12c sqlexception nosuchmethoderror

从过去 3 天开始,我遇到了 的简单连接问题。 Android - Oracle 12c 数据库。

最近上传了 Android-Oracle-Connection 但它适用于 11g 版本。我用过 ojdbc14.jar

我在该演示中使用了以下代码行:

/**
 * Driver for Oracle
 */
private static final String DEFAULT_DRIVER = "oracle.jdbc.driver.OracleDriver";


/**
 * URL to connect database
 */
private static final String DEFAULT_URL = "jdbc:oracle:thin:@192.168.0.102:1521:oracle"; // Change IP_Address:Database

/**
 * Creating Connection
 *
 * @param driver   driver object
 * @param url      url for db
 * @param username username
 * @param password password
 * @return Connection object
 * @throws ClassNotFoundException throwing exception
 * @throws SQLException           throwing exception
 */
public static Connection createConnection(String driver, String url, String username, String password) throws ClassNotFoundException, SQLException {
    Class.forName(driver);
    return DriverManager.getConnection(url, username, password);
}

现在的问题是,我使用的是 IP: 192.168.0.102 对于已成功连接但我更改 IP 的 11g 192.168.0.105 对于 12c 具有相同的代码,但它不工作。

我收到错误消息:
java.sql.SQLException: ORA-28040: No matching authentication protocol

我已经有checked this answer并尝试但得到错误:
W/oracle.jdbc: Error while registering Oracle JDBC Diagnosability MBean.
    java.lang.NoClassDefFoundError: Failed resolution of: Ljava/lang/management/ManagementFactory;
        at oracle.jdbc.driver.OracleDriver.registerMBeans(OracleDriver.java:321)
        at oracle.jdbc.driver.OracleDriver$1.run(OracleDriver.java:203)
        at java.security.AccessController.doPrivileged(AccessController.java:43)
        at oracle.jdbc.driver.OracleDriver.<clinit>(OracleDriver.java:199)
        at java.lang.Class.classForName(Native Method)
        at java.lang.Class.forName(Class.java:454)
        at java.lang.Class.forName(Class.java:379)

我已经有tried this answer也出现错误:
2019-11-23 16:36:12.564 28567-28567/com.demo.oracle E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.demo.oracle, PID: 28567
    java.lang.NoSuchMethodError: No static method metafactory(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite; in class Ljava/lang/invoke/LambdaMetafactory; or its super classes (declaration of 'java.lang.invoke.LambdaMetafactory' appears in /apex/com.android.runtime/javalib/core-oj.jar)
        at oracle.jdbc.driver.OracleDriver.<clinit>(OracleDriver.java:230)
        at java.lang.Class.classForName(Native Method)
        at java.lang.Class.forName(Class.java:454)
        at java.lang.Class.forName(Class.java:379)

我没有找到任何与 12c 相关的教程或文档。任何人都可以帮忙吗?

最佳答案

旧帖子但只是为了回答它,您必须在数据库服务器 sqlnet.ora 文件上添加一个参数以允许来自旧客户端的连接。当您的客户端较旧且服务器仅允许来自最新版本的 sqlnet 客户端的连接时,会发生此错误。示例 11g 客户端尝试连接到 18c 数据库服务器。

关于Android - Oracle 12c 数据库连接问题 : java. sql.SQLException: ORA-28040: 没有匹配的身份验证协议(protocol),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59006912/

相关文章:

android - 在可绘制选择器中更改实体的颜色

Oracle 连接未关闭

database - 为 Oracle 中的特定用户设置新密码时需要旧密码

android - 从 Android JNI 程序调用的 Log API 是什么?

android - 如何使用视口(viewport)使我的网站宽度适合移动设备的大小?

android - 电子邮件附件的 Intent 过滤器

java - Querydsl - 不相关表上的左连接

oracle - 如何在liquibase中添加复合外键?

sql - 甲骨文 12c : How can I modify an existing primary key column to an identity column?

sql - Oracle加入-常规语法VS ANSI语法之间的比较