Ошибка Android Studio и Connector/J

Задача: Связать apk приложение, созданное в Android Studio и локальный MySQL сервер на Windows.

Установка: Скачал MySQL Installer for Windows здесь, через него установил MySQL Server версии 8.0.29 x64 и Connector/J версии 8.0.29 x64. При конфигурации сервера ставил (всё, что не упомянул выключено):

Development Computer  
TCP/IP [enabled]  
Port 3306  
X Protocol Port 33060  
Open Windows Firewall ports for network access [enabled]  
Use Strong Password Encryption for Authentification (RECOMMENDED) [enabled]  
Password: xxxx  
Configure MySQL Server as a Windows Service [enabled]  
Windows Service Name: MySQL80  
Standard System Account [enabled]  
Add User: DB Admin ---- Password: xxxx ---- name: admin  
Hosts: <All Hosts (%)>  
Authentification MySQL [enabled]  
Start the MySQL Server at System Startup [emabled]  
MySQL user credentials password: xxxx  

Дальше просто клацал по кнопочками далее и сервер установлен.

Подготовка: запускаю MySQL 8.0 Command Line Client. Пароль xxxx (везде вводил один пароль). И череда команд:

CREATE DATABASE testdb;
use testdb;
create table test(id int, name text);
insert into test values(1, 'abc');
insert into test values(2, 'xyz');
exit;

Иду в C:\ProgramData\MySQL\MySQL Server 8.0\my.ini, в конце файла устанавливаю bind-address=<IPv4-адрес>, где <IPv4-адрес> (вместе со скобками <>) - мой IPv4-адрес, который я брал из cmd --> ipconfig. Сохраняю файл, иду в "Службы", где ищу MySQL80. Нажал, перезапустил его. Закрываю службы.

Действия: Создаю новый проект в IntelliJ IDEA Community Edition 2022.1.1, где пишу простой код для просмотра содержимого таблиц только что созданной базы данных, где ip - мой IpV4 из ipconfig (в следующем фрагменте кода так-же):

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class Main {

    public static void main(String[] args) {
        String connectionString = "jdbc:mysql://ip:3306/testdb";
        String username = "admin";
        String password = "xxxx";

        try {
            Connection connection = DriverManager.getConnection(connectionString, username, password);
            Statement command = connection.createStatement();
            ResultSet result = command.executeQuery("SELECT * FROM test");
            while (result.next()){
                System.out.println(result.getString(1) + " ---- " + result.getString(2));
            }
            command.close();
        }
        catch (Exception e){
            e.printStackTrace();
        }
    }
}

На выходе получаю:

1 ---- abc
2 ---- xyz

Process finished with exit code 0

Прекрасно, всё работает, переношу копируя всё, что написал в IntelliJ IDEA Community Edition 2022.1.1 в Android Studio:

MainActivity.java

package com.greenowl.android_mysql;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Button;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button showButton = findViewById(R.id.button);
        showButton.setOnClickListener(view -> {

            String connectionString = "jdbc:mysql://ip:3306/testdb";
            String username = "admin";
            String password = "xxxx";

            try {
                Connection connection = DriverManager.getConnection(connectionString, username, password);
                Statement command = connection.createStatement();
                ResultSet result = command.executeQuery("SELECT * FROM test");
                while (result.next()){
                    System.out.println(result.getString(1) + " ---- " + result.getString(2));
                }
                command.close();
            }
            catch (Exception e){
                e.printStackTrace();
            }
        });
    }
}    

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="com.greenowl.android_mysql">

    <uses-permission android:name="android.permission.INTERNET" />

    <application
        android:allowBackup="true"
        android:usesCleartextTraffic="true"
        android:dataExtractionRules="@xml/data_extraction_rules"
        android:fullBackupContent="@xml/backup_rules"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/Theme.AndroidMySQL"
        tools:targetApi="31">
        <activity
            android:name=".MainActivity"
            android:exported="true">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <Button
        android:id="@+id/button"
        android:layout_width="207dp"
        android:layout_height="75dp"
        android:text="Button"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout> 

В коде добавил строку <uses-permission android:name="android.permission.INTERNET" />, и скопировал Connector/J, и в режиме проекта вставил его в app/libs, после сделав "Add as Lib", то есть как внешнюю библиотеку, запуская на физическом телефоне при нажатии на кнопку получаю:

06/03 22:55:54: Launching 'app' on Xiaomi Redmi Note 8 Pro.
Install successfully finished in 314 ms.
$ adb shell am start -n "com.greenowl.android_mysql/com.greenowl.android_mysql.MainActivity" -a android.intent.action.MAIN -c android.intent.category.LAUNCHER
Connected to process 19775 on device 'xiaomi-redmi_note_8_pro-adb-buifzdrw8d8tu44x-f2tLJZ._adb-tls-connect._tcp'.
Capturing and displaying logcat messages from application. This behavior can be disabled in the "Logcat output" section of the "Debugger" settings page.
I/l.android_mysq: Late-enabling -Xcheck:jni
I/l.android_mysq: Unquickening 22 vdex files!
V/studio.deploy: Startup agent attached to VM
V/studio.deploy: No existing instrumentation found. Loading instrumentation from instruments-b4e5f589.jar
W/l.android_mysq: DexFile /data/data/com.greenowl.android_mysql/code_cache/.studio/instruments-b4e5f589.jar is in boot class path but is not in a known location
V/studio.deploy: Applying transforms with cached classes
W/l.android_mysq: Accessing hidden method Landroid/content/res/Resources;->overrideDisplayAdjustments(Ljava/util/function/Consumer;)V (blacklist, linking, denied)
W/l.android_mysq: Accessing hidden method Landroid/app/ResourcesManager;->updateResourcesForActivity(Landroid/os/IBinder;Landroid/content/res/Configuration;IZ)V (greylist-max-o, linking, denied)
W/l.android_mysq: Accessing hidden method Landroid/app/ResourcesManager;->getOrCreateActivityResourcesStructLocked(Landroid/os/IBinder;)Landroid/app/ResourcesManager$ActivityResources; (greylist-max-o, linking, denied)
W/l.android_mysq: Redefining intrinsic method java.lang.Thread java.lang.Thread.currentThread(). This may cause the unexpected use of the original definition of java.lang.Thread java.lang.Thread.currentThread()in methods that have already been compiled.
W/l.android_mysq: Redefining intrinsic method boolean java.lang.Thread.interrupted(). This may cause the unexpected use of the original definition of boolean java.lang.Thread.interrupted()in methods that have already been compiled.
D/NetworkSecurityConfig: No Network Security Config specified, using platform default
D/NetworkSecurityConfig: No Network Security Config specified, using platform default
D/libMEOW: meow reload base cfg path: na
D/libMEOW: meow reload overlay cfg path: /vendor/etc/meow.cfg
D/libMEOW: applied 1 plugins for [com.greenowl.android_mysql]:
D/libMEOW:   plugin 1: [libMEOW_gift.so]:
E/libc: Access denied finding property "ro.vendor.pref_scale_resolution"
D/View: com.greenowl.android_mysql initForcedUseForceDark: 1
E/l.android_mysq: Invalid ID 0x00000000.
D/DecorView[]: getWindowModeFromSystem  windowmode is 1
D/DecorView: createDecorCaptionView windowingMode:1 mWindowMode 1 isFullscreen: true
E/libc: Access denied finding property "ro.vendor.pref_scale_resolution"
E/libc: Access denied finding property "ro.vendor.pref_scale_resolution"
E/libc: Access denied finding property "ro.vendor.pref_scale_resolution"
W/l.android_mysq: Accessing hidden method Landroid/view/View;->computeFitSystemWindows(Landroid/graphics/Rect;Landroid/graphics/Rect;)Z (greylist, reflection, allowed)
W/l.android_mysq: Accessing hidden method Landroid/view/ViewGroup;->makeOptionalFitsSystemWindows()V (greylist, reflection, allowed)
I/SurfaceFactory: [static] sSurfaceFactory = com.mediatek.view.impl.SurfaceFactoryImpl@c609d77
D/ViewRootImpl[MainActivity]: hardware acceleration = true , fakeHwAccelerated = false, sRendererDisabled = false, forceHwAccelerated = false, sSystemRendererDisabled = false
D/libMEOW: applied 1 plugins for [com.greenowl.android_mysql]:
D/libMEOW:   plugin 1: [libMEOW_gift.so]:
I/InputTransport: Create ARC handle: 0xb400007ba57059c0
V/PhoneWindow: DecorView setVisiblity: visibility = 0, Parent = android.view.ViewRootImpl@9b79a13, this = DecorView@1d09450[MainActivity]
D/libMEOW: applied 1 plugins for [com.greenowl.android_mysql]:
D/libMEOW:   plugin 1: [libMEOW_gift.so]:
I/GED: [GT]_get_procNameprocess pid(19775)
I/GED: [GT]_getprocess name(com.greenowl.android_mysql)
I/l.android_mysq: [GT] ret(1) gt_status(00000000) aniso_debug_level(0) gt_aniso_max_level(16) ani so mask(00000001) tri mask(00000002)
I/libMEOW_gift: ctx:0xb400007bb24aaee8, ARC not Enabled.
E/ion: ioctl c0044901 failed with code -1: Invalid argument
E/libc: Access denied finding property "ro.vendor.pref_scale_resolution"
E/libc: Access denied finding property "ro.vendor.pref_scale_resolution"
W/System: A resource failed to call close. 
W/System: A resource failed to call close. 
I/System.out: [socket]:check permission begin!
W/System: ClassLoader referenced unknown path: system/framework/mediatek-cta.jar
I/System.out: [socket] e:java.lang.ClassNotFoundException: com.mediatek.cta.CtaUtils
W/System.err: java.sql.SQLNonTransientConnectionException: Could not create connection to database server.
W/System.err:     at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:110)
W/System.err:     at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
W/System.err:     at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89)
W/System.err:     at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:1001)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:818)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:448)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:241)
W/System.err:     at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:198)
W/System.err:     at java.sql.DriverManager.getConnection(DriverManager.java:580)
W/System.err:     at java.sql.DriverManager.getConnection(DriverManager.java:218)
W/System.err:     at com.greenowl.android_mysql.MainActivity.lambda$onCreate$0(MainActivity.java:27)
W/System.err:     at com.greenowl.android_mysql.MainActivity$$ExternalSyntheticLambda0.onClick(Unknown Source:0)
W/System.err:     at android.view.View.performClick(View.java:7575)
W/System.err:     at com.google.android.material.button.MaterialButton.performClick(MaterialButton.java:1194)
W/System.err:     at android.view.View.performClickInternal(View.java:7548)
W/System.err:     at android.view.View.access$3600(View.java:837)
W/System.err:     at android.view.View$PerformClick.run(View.java:28933)
W/System.err:     at android.os.Handler.handleCallback(Handler.java:938)
W/System.err:     at android.os.Handler.dispatchMessage(Handler.java:99)
W/System.err:     at android.os.Looper.loop(Looper.java:236)
W/System.err:     at android.app.ActivityThread.main(ActivityThread.java:8057)
W/System.err:     at java.lang.reflect.Method.invoke(Native Method)
W/System.err:     at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:620)
W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1011)
W/System.err: Caused by: android.os.NetworkOnMainThreadException
W/System.err:     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1605)
W/System.err:     at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:389)
W/System.err:     at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:230)
W/System.err:     at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:212)
W/System.err:     at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:436)
W/System.err:     at java.net.Socket.connect(Socket.java:631)
W/System.err:     at com.mysql.cj.protocol.StandardSocketFactory.connect(StandardSocketFactory.java:153)
W/System.err:     at com.mysql.cj.protocol.a.NativeSocketConnection.connect(NativeSocketConnection.java:63)
W/System.err:     at com.mysql.cj.NativeSession.connect(NativeSession.java:120)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:948)
W/System.err:   ... 20 more
I/l.android_mysq: ProcessProfilingInfo new_methods=0 is saved saved_to_disk=0 resolve_classes_delay=8000
V/PhoneWindow: DecorView setVisiblity: visibility = 4, Parent = android.view.ViewRootImpl@9b79a13, this = DecorView@1d09450[MainActivity]
I/GED: ged_boost_gpu_freq, level 100, eOrigin 2, final_idx 27, oppidx_max 27, oppidx_min 0

На виртуальной машине результат идентичен:

06/03 22:57:56: Launching 'app' on Pixel 3a API 30.
Install successfully finished in 1 s 585 ms.
$ adb shell am start -n "com.greenowl.android_mysql/com.greenowl.android_mysql.MainActivity" -a android.intent.action.MAIN -c android.intent.category.LAUNCHER
Connected to process 18943 on device 'emulator-5554'.
Capturing and displaying logcat messages from application. This behavior can be disabled in the "Logcat output" section of the "Debugger" settings page.
D/NetworkSecurityConfig: No Network Security Config specified, using platform default
D/NetworkSecurityConfig: No Network Security Config specified, using platform default
D/libEGL: loaded /vendor/lib/egl/libEGL_emulation.so
D/libEGL: loaded /vendor/lib/egl/libGLESv1_CM_emulation.so
D/libEGL: loaded /vendor/lib/egl/libGLESv2_emulation.so
W/l.android_mysq: Accessing hidden method Landroid/view/View;->computeFitSystemWindows(Landroid/graphics/Rect;Landroid/graphics/Rect;)Z (greylist, reflection, allowed)
W/l.android_mysq: Accessing hidden method Landroid/view/ViewGroup;->makeOptionalFitsSystemWindows()V (greylist, reflection, allowed)
D/HostConnection: HostConnection::get() New Host Connection established 0xeef7b570, tid 19009
D/HostConnection: HostComposition ext ANDROID_EMU_CHECKSUM_HELPER_v1 ANDROID_EMU_native_sync_v2 ANDROID_EMU_native_sync_v3 ANDROID_EMU_native_sync_v4 ANDROID_EMU_dma_v1 ANDROID_EMU_direct_mem ANDROID_EMU_host_composition_v1 ANDROID_EMU_host_composition_v2 ANDROID_EMU_vulkan ANDROID_EMU_deferred_vulkan_commands ANDROID_EMU_vulkan_null_optional_strings ANDROID_EMU_vulkan_create_resources_with_requirements ANDROID_EMU_YUV_Cache ANDROID_EMU_vulkan_ignored_handles ANDROID_EMU_has_shared_slots_host_memory_allocator ANDROID_EMU_vulkan_free_memory_sync ANDROID_EMU_vulkan_shader_float16_int8 ANDROID_EMU_vulkan_async_queue_submit ANDROID_EMU_sync_buffer_data ANDROID_EMU_read_color_buffer_dma GL_OES_vertex_array_object GL_KHR_texture_compression_astc_ldr ANDROID_EMU_host_side_tracing ANDROID_EMU_gles_max_version_2 
W/OpenGLRenderer: Failed to choose config with EGL_SWAP_BEHAVIOR_PRESERVED, retrying without...
D/EGL_emulation: eglCreateContext: 0xeef7b0a0: maj 2 min 0 rcv 2
D/EGL_emulation: eglMakeCurrent: 0xeef7b0a0: ver 2 0 (tinfo 0xef2bb9f0) (first time)
I/Gralloc4: mapper 4.x is not supported
D/HostConnection: createUnique: call
D/HostConnection: HostConnection::get() New Host Connection established 0xeef7ad20, tid 19009
D/goldfish-address-space: allocate: Ask for block of size 0x100
D/goldfish-address-space: allocate: ioctl allocate returned offset 0x3f3ffe000 size 0x2000
D/HostConnection: HostComposition ext ANDROID_EMU_CHECKSUM_HELPER_v1 ANDROID_EMU_native_sync_v2 ANDROID_EMU_native_sync_v3 ANDROID_EMU_native_sync_v4 ANDROID_EMU_dma_v1 ANDROID_EMU_direct_mem ANDROID_EMU_host_composition_v1 ANDROID_EMU_host_composition_v2 ANDROID_EMU_vulkan ANDROID_EMU_deferred_vulkan_commands ANDROID_EMU_vulkan_null_optional_strings ANDROID_EMU_vulkan_create_resources_with_requirements ANDROID_EMU_YUV_Cache ANDROID_EMU_vulkan_ignored_handles ANDROID_EMU_has_shared_slots_host_memory_allocator ANDROID_EMU_vulkan_free_memory_sync ANDROID_EMU_vulkan_shader_float16_int8 ANDROID_EMU_vulkan_async_queue_submit ANDROID_EMU_sync_buffer_data ANDROID_EMU_read_color_buffer_dma GL_OES_vertex_array_object GL_KHR_texture_compression_astc_ldr ANDROID_EMU_host_side_tracing ANDROID_EMU_gles_max_version_2 
W/System.err: java.sql.SQLNonTransientConnectionException: Could not create connection to database server.
W/System.err:     at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:110)
W/System.err:     at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
W/System.err:     at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:89)
W/System.err:     at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:63)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:1001)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:818)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:448)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:241)
W/System.err:     at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:198)
W/System.err:     at java.sql.DriverManager.getConnection(DriverManager.java:580)
W/System.err:     at java.sql.DriverManager.getConnection(DriverManager.java:218)
W/System.err:     at com.greenowl.android_mysql.MainActivity.lambda$onCreate$0(MainActivity.java:27)
W/System.err:     at com.greenowl.android_mysql.MainActivity$$ExternalSyntheticLambda0.onClick(Unknown Source:0)
W/System.err:     at android.view.View.performClick(View.java:7448)
W/System.err:     at com.google.android.material.button.MaterialButton.performClick(MaterialButton.java:1194)
W/System.err:     at android.view.View.performClickInternal(View.java:7425)
W/System.err:     at android.view.View.access$3600(View.java:810)
W/System.err:     at android.view.View$PerformClick.run(View.java:28305)
W/System.err:     at android.os.Handler.handleCallback(Handler.java:938)
W/System.err:     at android.os.Handler.dispatchMessage(Handler.java:99)
W/System.err:     at android.os.Looper.loop(Looper.java:223)
W/System.err:     at android.app.ActivityThread.main(ActivityThread.java:7656)
W/System.err:     at java.lang.reflect.Method.invoke(Native Method)
W/System.err:     at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:592)
W/System.err:     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)
W/System.err: Caused by: android.os.NetworkOnMainThreadException
W/System.err:     at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1605)
W/System.err:     at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:389)
W/System.err:     at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:230)
W/System.err:     at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:212)
W/System.err:     at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:436)
W/System.err:     at java.net.Socket.connect(Socket.java:621)
W/System.err:     at com.mysql.cj.protocol.StandardSocketFactory.connect(StandardSocketFactory.java:153)
W/System.err:     at com.mysql.cj.protocol.a.NativeSocketConnection.connect(NativeSocketConnection.java:63)
W/System.err:     at com.mysql.cj.NativeSession.connect(NativeSession.java:120)
W/System.err:     at com.mysql.cj.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:948)
W/System.err:   ... 20 more

Что не так? Вроде же использовал всё тоже самое, и подключался по IP а не по localhost, и не по 10.0.2.2. Что делать? Как исправить ситуацию. Возможно это связано с тем, что при попытке входа в MySQL Server после этих всех действий пароль уже не действителен? Этого я тоже не понимаю. Нигде его не менял, ничего с ним не делал, но после этих действий приходиться переустанавливать сервер. Спасибо.

EDIT: Разобрался с проблемой. Для этого необходимо было изменить код MainActivity.java на:

package com.greenowl.android_mysql;

import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.Button;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button showButton = findViewById(R.id.button);
        showButton.setOnClickListener(view -> {
            new Thread(() -> {
                String connectionString = "jdbc:mysql://ip:3306/testdb?useSSL=false";
                String username = "admin";
                String password = "xxxx";

                try {
                    Connection connection = DriverManager.getConnection(connectionString, username, password);
                    Statement command = connection.createStatement();
                    ResultSet result = command.executeQuery("SELECT * FROM test");
                    while (result.next()){
                        System.out.println(result.getString(1) + " ---- " + result.getString(2));
                    }
                    command.close();
                }
                catch (Exception e){
                    e.printStackTrace();
                }
            }).start();
        });
    }
}

Также я вместо моего локального ip в my.ini поставил 0.0.0.0 для надежности. Еще пришлось заменить Connector/J версии 8.0.29 x64 на mysql-connector-java-5.1.46-bin.jar.

Очень помогла статья. Четко расписано что да как сделать. Также в конце строки connectionString добавляем "?useSSL=false" - так работает без предупреждений, хотя и с ними уже всё в норме.


Ответы (0 шт):