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 中的其他线程管理技术来执行查询。

相关推荐

最新推荐

recommend-type

Android连接MySQL数据库并进行增删改查操作示例讲解

主要介绍了Android 连接MySQL数据库并进行增删改查操作示例讲解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
recommend-type

Django读取Mysql数据并显示在前端的实例

今天小编就为大家分享一篇Django读取Mysql数据并显示在前端的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

MySQL误操作后快速恢复数据的方法

基本上每个跟数据库打交道的程序员(当然也可能是你同事)都会碰一个问题,MySQL误操作后如何快速回滚?比如,delete一张表,忘加限制条件,整张表没了。假如这还是线上环境核心业务数据,那这事就闹大了。误操作后...
recommend-type

Python爬取数据并写入MySQL数据库的实例

今天小编就为大家分享一篇Python爬取数据并写入MySQL数据库的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

mysql查询结果输出到文件的方法

mysql查询结果导出/输出/写入到文件 方法一: 直接执行命令: mysql&gt; select count(1) from table into outfile ‘/tmp/test.xls’; Query OK, 31 rows affected (0.00 sec) 在目录/tmp/下会产生文件test.xls 遇到...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

HSV转为RGB的计算公式

HSV (Hue, Saturation, Value) 和 RGB (Red, Green, Blue) 是两种表示颜色的方式。下面是将 HSV 转换为 RGB 的计算公式: 1. 将 HSV 中的 S 和 V 值除以 100,得到范围在 0~1 之间的值。 2. 计算色相 H 在 RGB 中的值。如果 H 的范围在 0~60 或者 300~360 之间,则 R = V,G = (H/60)×V,B = 0。如果 H 的范围在 60~120 之间,则 R = ((120-H)/60)×V,G = V,B = 0。如果 H 的范围在 120~180 之间,则 R = 0,G = V,B =
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。