java - 如何修复此错误:I/System.out: java.lang.ClassNotFoundException: com.mysql.jdbc.driver java.lang.NullPointerException
问题描述
我正在尝试将我的应用程序与 MySQL 数据库连接起来。我下载了 MySQL/Java 连接器并将 .jar 文件添加到我的库中,但它不起作用,而且我总是收到以下消息:
I/System.out:java.lang.ClassNotFoundException:com.mysql.jdbc.driver java.lang.NullPointerException
构建.gradle
android {
compileSdkVersion 29
buildToolsVersion "29.0.2"
defaultConfig {
applicationId "com.example.myapp"
minSdkVersion 15
targetSdkVersion 29
versionCode 1
versionName "1.0"
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility = 1.8
targetCompatibility = 1.8
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'androidx.appcompat:appcompat:1.0.2'
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test.ext:junit:1.1.0'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
//compile group: 'mysql', name: 'mysql-connector-java', version: '8.0.18'
implementation files('libs/mysql-connector-java-8.0.18.jar')
}
我尝试与数据库连接的班级:
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.net.HttpURLConnection;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLEncoder;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import android.os.AsyncTask;
import android.widget.EditText;
import java.sql.*;
import java.util.ArrayList;
import com.mysql.jdbc.Driver;
public class DBConnection {
public Connection getConnection() throws Exception
{
try {
String driver = "com.mysql.jdbc.driver";
String url = "jdbc:mysql://127.0.0.1:3306/test";
String username = "root";
String password = "";
Class.forName(driver).newInstance();
Connection c = DriverManager.getConnection(url, username, password);
System.out.println("Connected");
}catch (Exception e)
{
System.out.println(e);
}
return null;
}
ArrayList<String> array = new ArrayList<>();
public String read(EditText e1)
{
try{
Connection c = getConnection();
PreparedStatement statement = c.prepareStatement("SELECT c_name FROM c_customer;");
ResultSet resultSet = statement.executeQuery();
while (resultSet.next())
{
array.add(resultSet.getString("c_name"));
}
e1.setText(array.get(0));
System.out.printf("Successfull");
}catch (Exception e)
{
System.out.println(e);
}
return null;
}
}
MainActivity.java
import androidx.appcompat.app.AppCompatActivity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
public class MainActivity extends AppCompatActivity {
DBConnection db;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final EditText user = findViewById(R.id.nameInput);
final EditText pass = findViewById(R.id.passwortInput);
Button login = findViewById(R.id.loginButton);
login.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
db = new DBConnection();
db.read(user);
}
}
});
}
}
我希望你能帮助我。
解决方案
虽然我无法帮助您处理 ClassNotFoundException(因为我之前没有使用过 Gradle),但我可以告诉您 NullPointerException 是因为您没有在 getConnection() 方法中返回 Connection。您只需在 try/catch 块的末尾返回 null 。在 try 块中返回变量 c 并在 catch 块中返回 null。
此外,您的 read 方法也不会返回字符串,同样只是 null。设置 EditText 后返回您的字符串,或者如果您所做的只是更新参数值,则使该方法无效。
最后,我认为您不需要在 getConnection() 方法中抛出异常,因为您已经在 try/catch 块中处理了它。祝你好运找到另一个问题。
推荐阅读
- database - 具有“。”的数据库 而不是 'localhost' 没有显示
- amazon-web-services - 自定义域 + 在 SES 接收
- android - 如何修改代码以在 android 中显示图像幻灯片?
- java - jsp页面在使用请求调度程序时加载css
- regex - 使用 REGEX 作为条件的 COUNTIFS
- apache - Traefik 在后端重定向的情况下不会修改位置标头
- digital-ocean - 如何获取运行 Kubernetes cert-manager 的证书
- vba - 如何将信息输出到列表框?
- javascript - 将 Lottie SVG 居中到 Header 元素
- pycharm - 最新的 Pycharm 对 brew 安装版本说“Interpeter 似乎无效”