Как подключить godaddy mysql в приложении javafx - PullRequest
0 голосов
/ 08 декабря 2018

У меня проблема с подключением моего соединения GoDaddy MySQL в приложении javafx для настольных ПК и Android.Я хочу подключиться напрямую к MySQL, расположенному в GoDaddy, без использования технологии ssh.

Это мой файл Main.java:

package com.maqboolsolutions.mysql_ssh_android;

import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javafx.application.Application;
import javafx.stage.Stage;

public class Main extends Application {

    String HOST = ""; // Hosting provider ip address / name (e.g. example.com)
    String DB_NAME = ""; // Database name (e.g. db_test)

    String DB_URL = "jdbc:mysql://" + HOST + ":3306/" + DB_NAME;

    String USERNAME = ""; // mysql database user name (e.g. admin)
    String PASSWORD = ""; // mysql database password (e.g. 123)

    @Override
    public void start(Stage primaryStage) throws IOException {
        getConnection();
    }

    private void getConnection() {
        try {
            //mysql database connectivity
            Class.forName("com.mysql.cj.jdbc.Driver");

            Connection con = DriverManager.getConnection(DB_URL, USERNAME, PASSWORD);

            System.out.println("Database connection established");
            System.out.println("DONE");

        } catch (ClassNotFoundException | SQLException ex) {
            Logger.getLogger(DBConnection.class.getName()).log(Level.SEVERE, null, ex);
            System.exit(0);
        }
    }

    public static void main(String[] args) {
        launch(args);
    }
}

Это gradle.build:

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'org.javafxports:jfxmobile-plugin:1.3.16'
    }
}

apply plugin: 'org.javafxports.jfxmobile'

repositories {
    jcenter()
    maven {
        url 'http://nexus.gluonhq.com/nexus/content/repositories/releases'
    }
}

mainClassName = 'com.maqboolsolutions.mysql_ssh_android.Main'

dependencies {
    compile 'com.gluonhq:charm:5.0.2'

    compile 'mysql:mysql-connector-java:8.0.13'
    compile 'com.jcraft:jsch:0.1.54'
}

jfxmobile {
    downConfig {
        version = '3.8.6'
        // Do not edit the line below. Use Gluon Mobile Settings in your project context menu instead
        plugins 
    }

    android {
        manifest = 'src/android/AndroidManifest.xml'

        javafxportsVersion = '8.60.11'

        android {
            manifest = 'src/android/AndroidManifest.xml'

            packagingOptions {
                exclude 'META-INF/INDEX.LIST'
            }

            dexOptions {
                javaMaxHeapSize "4g"
            }
        }
    }
}

Это ошибка / трассировка стека:

Executing: gradle :mysql_ssh_androidApp:run
Arguments: [-PcmdLineArgs=, -PjvmLineArgs=, -c, C:\Users\MaqboolSoftPC\Documents\NetBeansProjects\mysql-ssh-android\mysql_ssh_android\settings.gradle]

:mysql_ssh_androidApp:compileJava
:mysql_ssh_androidApp:processResources UP-TO-DATE
:mysql_ssh_androidApp:classes
:mysql_ssh_androidApp:compileDesktopJava NO-SOURCE
:mysql_ssh_androidApp:processDesktopResources NO-SOURCE
:mysql_ssh_androidApp:desktopClasses UP-TO-DATE
Dec 08, 2018 10:46:19 AM com.maqboolsolutions.mysql_ssh_android.Main getConnection
SEVERE: null
java.sql.SQLException: Access denied for user 'admin'@'example.com' (using password: YES)
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:129)
    at com.mysql.cj.jdbc.exceptions.SQLError.createSQLException(SQLError.java:97)
    at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:122)
    at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:835)
    at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:455)
    at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:240)
    at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:207)
    at java.sql.DriverManager.getConnection(DriverManager.java:664)
    at java.sql.DriverManager.getConnection(DriverManager.java:247)
    at com.maqboolsolutions.mysql_ssh_android.Main.getConnection(Main.java:39)
    at com.maqboolsolutions.mysql_ssh_android.Main.start(Main.java:31)
    at com.sun.javafx.application.LauncherImpl.lambda$launchApplication1$161(LauncherImpl.java:863)
    at com.sun.javafx.application.PlatformImpl.lambda$runAndWait$174(PlatformImpl.java:326)
    at com.sun.javafx.application.PlatformImpl.lambda$null$172(PlatformImpl.java:295)
    at java.security.AccessController.doPrivileged(Native Method)
    at com.sun.javafx.application.PlatformImpl.lambda$runLater$173(PlatformImpl.java:294)
    at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:95)
    at com.sun.glass.ui.win.WinApplication._runLoop(Native Method)
    at com.sun.glass.ui.win.WinApplication.lambda$null$147(WinApplication.java:177)
    at java.lang.Thread.run(Thread.java:748)

:mysql_ssh_androidApp:run

BUILD SUCCESSFUL in 4s
3 actionable tasks: 2 executed, 1 up-to-date

Я уже добавляю свой IP-адрес в godaddy Удаленный MySQL , как показано.

enter image description here

Если я использую технику ssh, то она работает на рабочем столе, а не на устройстве Android.Смотрите мой пост Javafx android mysql connect over ssh .

Ответы [ 2 ]

0 голосов
/ 17 декабря 2018

Хорошо!Хорошо!Хорошо! ....

Я действительно решил свою проблему до последних двух дней вечера ...

Решения очень просты ...

Следуй за мной:

Перейдите на google.com и выполните поиск, подобный этому find my ip address, как показано на рисунке:

enter image description here

Введите этот общедоступный IP-адрес в godaddy remote mysql настройка страницы нажатием кнопки remote MySQL, как показано:

enter image description here

Добавить, затем введите свой общедоступный IP-адрес в следующем поле:

enter image description here

Затем напишите свою Java-программу для тестирования.Это работает на рабочем столе также и Android-устройства.Для подключения к удаленному MySQL (godaddy mysql) вам не нужна техника ssh.Только ваш ip должен иметь разрешение на подключение сервера Godaddy (публичный ip).

Если меня смущает какая-либо путаница ......

0 голосов
/ 08 декабря 2018

Нет, вы не хотите напрямую подключаться к mysql.Не с андроида.Для этого вам нужно ввести свой пароль для базы данных в вашем приложении, что означает, что ваша база данных будет взломана.Правильный способ сделать это - настроить веб-сервис и обращаться к БД только из веб-сервиса.После этого приложение для Android будет вызывать веб-службу.

Те же правила применяются к настольному приложению.Единственные приложения, которые подключаются напрямую к вашей базе данных, должны быть приложениями, запущенными на ваших собственных серверах.

...