gpt4 book ai didi

android - 如何在 Eclipse 中正确安装 mysql 连接器?

转载 作者:行者123 更新时间:2023-11-30 01:34:44 26 4
gpt4 key购买 nike

首先,我想说这是我大学类(class)的一个项目,同时也是我的第一个 Android 应用程序,它比计算器更复杂,所以我知道我可以做一些不可原谅的错误,但我的首要任务是代码应该工作。它可能不安全并且不考虑某些情况,但只要这些情况不会出现,它就会出现。

我的应用程序打算在 Android 上运行,首先应该出现登录屏幕,它接受登录名和密码,生成密码的哈希值并联系 Web 服务器上的数据库以比较哈希值。有人告诉我使用免费数据库 db4free.net。

我创建了一个类 Serwer,它专门负责联系数据库。据我从教程和 stackoverflow 问题和答案中了解到,连接应包括:

  1. 加载驱动程序,
  2. 在 DriverManager 类中注册它,
  3. 使用 getConnection 方法打开连接,传递凭据,
  4. 准备和执行 SQL 查询,
  5. 获取结果集。

我还了解到我应该下载一个 mysql-connector-java-5.1.38-bin.jar 文件。正如 stackoverflow 上的一些线程所建议的那样,我将它复制到项目的主目录中(我必须复制工作区并在完成后带到教授的计算机上),将它作为外部库添加到属性的库选项卡中。现在,当我在我的智能手机上运行该项目时,出现了 java.lang.ClassNotFoundException: Didn't find class "com.mysql.jdbc.Driver" 错误。我还尝试在 Order 和 Export 选项卡中检查库 - 然后它甚至无法编译,返回 Conversion to Dalvik format failed with error 1

我在其他 stackoverflow 线程中尝试过许多场景,例如在许多配置中清理项目、更改构建路径的顺序等。我怀疑我犯了一个我没有看到的简单、愚蠢的错误并且我希望你能认出它。

这是我的服务器类:

package com.planer.serwer;

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

import com.planer.MainActivity;
import com.example.planer.R;
import com.planer.pracownik.Pracownik;

public class Serwer {
private Connection conn = null;
private static Driver driver;
private static int status;
private MainActivity parentActivity;

private final String user = parentActivity.getResources().getString(R.string.db_login);
private final String pass = parentActivity.getResources().getString(R.string.db_pass);
private final String url= "jdbc:mysql://db4free.net:3306/kalendarzplaner";

public static final int STATUS_GOOD = 0;
public static final int STATUS_NO_CONNECTION = 1;
public static final int STATUS_NOT_AUTHENTICATED = 2;
public static final int STATUS_SQL_EXCEPTION = 4;
public static final int STATUS_NO_DRIVER = 8;


public Serwer(MainActivity parentActivity){
status = STATUS_NO_CONNECTION;
try {
driver = new com.mysql.jdbc.Driver();
} catch (Exception ex) {
status |= STATUS_NO_DRIVER;
} catch (NoClassDefFoundError e){
status |= STATUS_NO_DRIVER;
}
this.parentActivity = parentActivity;
}

public Pracownik authorize(String login, String passhash){
Pracownik pracownik = new Pracownik("","",false,status);
status |= this.polacz();
if(status != Serwer.STATUS_GOOD) {
pracownik.status |= status;
return pracownik;
}
Statement statement = null;
ResultSet resultSet = null;
String query = "select passhash, imie_nazwisko, czy_kierownik from auth where login='" + login + "';";
try {
statement = conn.prepareStatement(query);
resultSet = statement.executeQuery(query);
resultSet.first();
if(resultSet.getString("passhash").toString().compareTo(passhash)!= 0){
status |= Serwer.STATUS_NOT_AUTHENTICATED;
pracownik.status |= status;
return pracownik;
}
pracownik.login = login;
pracownik.imie_nazwisko = resultSet.getString("imie_nazwisko");
pracownik.czy_kierownik = resultSet.getBoolean("czy_kierownik");
} catch (SQLException ex) {
pracownik.status |= Pracownik.STATUS_SQL_EXCEPTION;
}
return pracownik;
}


public int polacz() {
int done = STATUS_NO_CONNECTION;
if((status & STATUS_NO_DRIVER) != 0)
return done;
// Connection
try {
DriverManager.registerDriver(driver);
conn = DriverManager.getConnection(url, user, pass);
done = Serwer.STATUS_GOOD;
} catch (java.sql.SQLException ex) {
done |= Serwer.STATUS_SQL_EXCEPTION;
System.out.println("SQLException: " + ex.getMessage());
}
return done;
}
}

正如我所说,授权方法的结果状态为 9,这是未加载驱动程序时的预期结果。我还附加了我的工作区内容。

Workspace

最佳答案

首先,我想首先建议您试用 Android Studio。它是专为 Android 开发而开发的更现代的新 IDE。

其次,在 Android 上联系数据库与在桌面应用程序中从 Java/C# 联系数据库有很大不同。

要联系在线 MySQL 数据库,您需要一个 RESTful 服务(例如用 PHP 编写)从数据库获取数据并将其发送到应用程序。该服务就像应用程序和数据库之间的通信点。该服务通常以 JSON 等对人类不友好的格式向应用程序发送数据,因此您的应用程序需要解析并显示它。

关于android - 如何在 Eclipse 中正确安装 mysql 连接器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35244924/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com