如何在 javafx 应用程序中连接 Godaddy mysql

Posted

技术标签:

【中文标题】如何在 javafx 应用程序中连接 Godaddy mysql【英文标题】:How to connect godaddy mysql in javafx application 【发布时间】:2018-12-08 06:04:28 【问题描述】:

我在 javafx 桌面/android 应用程序中连接我的 GoDaddy mysql 连接时遇到问题。我想直接连接到位于 GoDaddy 的 MySQL,而不使用 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

我已经在godaddy Remote MySQL中添加了我的IP地址,如图所示。

如果我使用 ssh 技术,那么它可以在桌面上运行,而不是在 android 设备上运行。请参阅我的帖子Javafx android mysql connect over ssh。

【问题讨论】:

从 JavaFX 应用程序连接需要您的 MySQL 服务器可公开访问,这将是一个坏主意(或者需要某种 *** 或白名单设置)。重新考虑您的设计,并可能使用 REST 服务在您的应用程序和数据库之间进行调解。 任何想法!或者可能是最好的任何教程/资源。 【参考方案1】:

不,您不想直接连接到 mysql。不是来自安卓。为此,您需要在应用程序中输入数据库的密码,这意味着您的数据库将受到威胁。这样做的正确方法是设置一个 web 服务,并且只从 web 服务访问数据库。然后,Android 应用程序将调用 Web 服务。

相同的规则适用于桌面应用程序。唯一直接连接到您的数据库的应用程序应该是在您自己的服务器上运行的应用程序。

【讨论】:

【参考方案2】:

好的!行!好的!....

前两天晚上我真的解决了我的问题......

解决方法很简单……

跟我来:

去google.com这样搜索find my ip address如图:

点击remote MySQL按钮在godaddy remote mysql设置页面输入这个公网IP地址,如图:

添加然后在以下字段中输入您的公共 IP:

然后编写您的 java 程序进行测试。它也适用于桌面和 android 设备。要连接到远程 MySQL (godaddy mysql),您不需要 ssh 技术。只有你的ip必须有权限连接godaddy服务器(公共ip)。

如果我有任何困惑......

【讨论】:

以上是关于如何在 javafx 应用程序中连接 Godaddy mysql的主要内容,如果未能解决你的问题,请参考以下文章

JavaFx 离线能力?

我的可执行 JavaFX 文件如何连接到 MySQL 数据库?

JavaFX MySQL连接示例请

如何使用 JavaFXPorts 在 android 中启用 JavaFX 虚拟键盘

JavaFX概览

如何在 JavaFX 中获取 Stage 的窗口句柄 (hWnd)?