Android登录MySQL后查找数据并输出的详细代码
时间: 2024-05-09 09:15:25 浏览: 11
以下是一个简单的 Android 登录 MySQL 数据库并查找数据并输出的示例代码:
首先,在 Android 项目的 `build.gradle` 文件中添加以下依赖项:
```gradle
implementation 'mysql:mysql-connector-java:8.0.23'
```
接下来,在 Android 的登录活动中,添加以下代码来连接 MySQL 数据库并查询数据:
```java
public class LoginActivity extends AppCompatActivity {
private static final String URL = "jdbc:mysql://your_mysql_host:your_mysql_port/your_database_name";
private static final String USER = "your_mysql_username";
private static final String PASSWORD = "your_mysql_password";
private EditText mUsernameEditText;
private EditText mPasswordEditText;
private Button mLoginButton;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_login);
mUsernameEditText = findViewById(R.id.username_edit_text);
mPasswordEditText = findViewById(R.id.password_edit_text);
mLoginButton = findViewById(R.id.login_button);
mLoginButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
String username = mUsernameEditText.getText().toString();
String password = mPasswordEditText.getText().toString();
if (TextUtils.isEmpty(username) || TextUtils.isEmpty(password)) {
Toast.makeText(LoginActivity.this, "Please enter username and password", Toast.LENGTH_SHORT).show();
return;
}
new LoginTask().execute(username, password);
}
});
}
private class LoginTask extends AsyncTask<String, Void, Boolean> {
private ProgressDialog mProgressDialog;
@Override
protected void onPreExecute() {
super.onPreExecute();
mProgressDialog = new ProgressDialog(LoginActivity.this);
mProgressDialog.setMessage("Logging in...");
mProgressDialog.setCancelable(false);
mProgressDialog.show();
}
@Override
protected Boolean doInBackground(String... params) {
String username = params[0];
String password = params[1];
try {
Class.forName("com.mysql.jdbc.Driver");
Connection connection = DriverManager.getConnection(URL, USER, PASSWORD);
Statement statement = connection.createStatement();
ResultSet resultSet = statement.executeQuery("SELECT * FROM users WHERE username='" + username + "' AND password='" + password + "'");
boolean found = resultSet.next();
resultSet.close();
statement.close();
connection.close();
return found;
} catch (ClassNotFoundException | SQLException e) {
e.printStackTrace();
}
return false;
}
@Override
protected void onPostExecute(Boolean result) {
super.onPostExecute(result);
mProgressDialog.dismiss();
if (result) {
// Login successful, start main activity
Intent intent = new Intent(LoginActivity.this, MainActivity.class);
startActivity(intent);
finish();
} else {
// Login failed, show error message
Toast.makeText(LoginActivity.this, "Invalid username or password", Toast.LENGTH_SHORT).show();
}
}
}
}
```
在上面的代码中,我们使用了一个名为 `LoginTask` 的 `AsyncTask` 来连接 MySQL 数据库并查询用户是否存在。在 `doInBackground` 方法中,我们使用 `DriverManager` 来获取一个 `Connection` 对象,并使用该对象创建一个 `Statement` 对象,用于执行 SQL 查询语句。然后,我们执行一个查询语句,以查找具有给定用户名和密码的用户。最后,我们关闭 `ResultSet`、`Statement` 和 `Connection` 对象,并返回一个布尔值,以指示查询是否找到了用户。
在 `onPostExecute` 方法中,我们检查查询结果是否为真。如果是,则登录成功,并启动主活动。否则,我们显示一个错误消息。
请注意,上面的代码中使用的是同步查询,这可能会导致 Android 应用程序的主线程被阻塞。为了避免这种情况,我们可以将查询放在异步任务中,或使用 Android 中的其他线程管理技术来执行查询。