UnsupportedOperationException 与 Android 上的 DriverManager.getConnection()

Posted

技术标签:

【中文标题】UnsupportedOperationException 与 Android 上的 DriverManager.getConnection()【英文标题】:UnsupportedOperationException with DriverManager.getConnection() on Android 【发布时间】:2019-11-14 11:01:51 【问题描述】:

我无法将 JDBC 连接到我的数据库,出现以下错误

Error :  E/androidRuntime: FATAL EXCEPTION: main
 Process: com.example.myprojectapplication, PID: 32686
 java.lang.RuntimeException: Unable to start activity ComponentInfocom.example.myprojectapplication/com.example.myprojectapplication.MainActivity:
 java.lang.UnsupportedOperationException
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2646)
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707)
     at android.app.ActivityThread.-wrap12(ActivityThread.java)
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460)
     at android.os.Handler.dispatchMessage(Handler.java:102)
     at android.os.Looper.loop(Looper.java:154)
     at android.app.ActivityThread.main(ActivityThread.java:6077)
     at java.lang.reflect.Method.invoke(Native Method)
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866)
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756)
 Caused by: java.lang.UnsupportedOperationException
     at java.util.regex.Matcher.group(Matcher.java:383)
     at com.mysql.cj.conf.ConnectionUrlParser.isConnectionStringSupported(ConnectionUrlParser.java:152)
     at com.mysql.cj.conf.ConnectionUrl.acceptsUrl(ConnectionUrl.java:258)
     at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:187)
     at java.sql.DriverManager.getConnection(DriverManager.java:569)
     at java.sql.DriverManager.getConnection(DriverManager.java:219)
     at com.example.myprojectapplication.ObjectClass.JDBC.CONN(JDBC.java:19)
     at com.example.myprojectapplication.MainActivity.onCreate(MainActivity.java:72)
     at android.app.Activity.performCreate(Activity.java:6662)
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118)
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2599)
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707) 
     at android.app.ActivityThread.-wrap12(ActivityThread.java) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:154) 
     at android.app.ActivityThread.main(ActivityThread.java:6077) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756)
package com.example.myprojectapplication.ObjectClass;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;


public class JDBC 

    public void CONN() 
        Connection con = null;

        try 
            String url = "jdbc:mysql://localhost:3306/prog";
            String username = "root";
            String password = "mysql";

            Class.forName("com.mysql.jdbc.Driver");
            con = DriverManager.getConnection(url, username, password);

            if (con != null) 
                System.out
                        .println("Successfully connected to MySQL database test");
            

         catch (SQLException ex) 
            System.out
                    .println("An error occurred while connecting MySQL databse");
            ex.printStackTrace();
         catch (ClassNotFoundException e) 
            e.printStackTrace();
         catch (UnsupportedOperationException exa)
            exa.printStackTrace();
        

    

【问题讨论】:

请发布完整的异常堆栈跟踪(请edit您的问题添加信息,不要使用cmets)。 好的,谢谢,我做到了! @MarkRotteveel 能否请您添加 MainActivity 类中的代码。 Connection 类不会抛出异常。 你的项目中有 MySql Jar/Dependency 吗? @SwaritAgarwal 是的,我在依赖项中添加了它 --> " implementation files('libs/mysql-connector-java-5.1.47.jar')" 【参考方案1】:

根据堆栈跟踪,您使用的 MySQL 连接器/J 版本正在使用 Android 不支持的java.util.regex.Matcher 功能(可能是named groups)。解决方法是使用 5.1.x 版本的 MySQL Connector/J 而不是 8.0.x 版本。

但是,您不应该在 Android 应用程序中使用 JDBC。直接连接到数据库是不安全的,并且通常性能很差。正确的解决方案是编写一个 REST 服务(或其他形式的 Web 服务)来在您的 Android 应用程序和数据库之间进行调解。

【讨论】:

好吧好吧,在我看来这是一个很好的解决方案,但实际上什么是服务以及如何创建服务? @MatClt en.wikipedia.org/wiki/Representational_state_transfer 是的,当然,但通常它们已经存在,我们应该创建一个吗?也许这是一个愚蠢的问题 mdrr【参考方案2】:

我可能会迟到回答这个问题,但经过数小时尝试不同的解决方案,就像我要放弃 android 和 jconnector 一样,我尝试了以下方法,它对我有用。

要使用 Android 应用程序中的 jconnector 连接到运行 MySQL 版本 8 和/或 5.7 的 MySQL 远程服务器,此解决方案适用于我:

请注意,我在这里建议的旧版本的 jconnector 不能与远程 MySQL 8 服务器一起使用!

我尝试将 mysql-connector-java-8.xxx.jar 与“com.mysql.cj.jdbc.Driver”一起使用,但它在 Android 应用程序上也不起作用。只有当您使用 java swing 或其他 java 应用程序并且再次“不在 android 上”时,它才会起作用!

安卓解决方案:

    下载/或导入 mysql-connector-java-5.1.49.jar 作为您的连接器 jar 文件并将其替换为您的连接器类! (请注意,以下版本将/可能不起作用!) 使用此连接器类:Class.forName("com.mysql.jdbc.Driver").newInstance();

【讨论】:

【参考方案3】:

可能意味着你配置中的msql驱动信息与你代码中的加载驱动不匹配。高版本的mysql驱动注册,试试这个方法:Class.forName("com.mysql.cj.jdbc.Driver");

【讨论】:

以上是关于UnsupportedOperationException 与 Android 上的 DriverManager.getConnection()的主要内容,如果未能解决你的问题,请参考以下文章