我已成功将我的 Java 应用程序连接到 MySQL,然后我希望用户输入他们的用户名和密码。然后它会向 MySQL 发送查询并查找具有该用户名的位置,然后将给定的密码与数据库中的密码进行比较。在大多数情况下,这是有效的。假设用户名是“ABC”,密码是“def”。如果提示输入用户名并输入“ABC def”,则表示成功,密码“def a”相同。我相信问题出在 rs.next() 上,它只检查空格之前的任何文本。
有什么解决方案的想法吗?
String databaseUsername = "";
String databasePassword = "";
// Check Username and Password
System.out.print("Enter Username: ");
String name = sc.next();
System.out.print("Enter Password: ");
String password = sc.next();
// Create SQL Query
Statement stmt = connection.createStatement();
String SQL = "SELECT * FROM users WHERE users_name='" + name + "' && users_password='" + password+ "'";
ResultSet rs = stmt.executeQuery(SQL);
// Check Username and Password
while (rs.next()) {
databaseUsername = rs.getString("users_name");
databasePassword …Run Code Online (Sandbox Code Playgroud)