- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我编写了一个所谓的“错误较少”代码,但在使用该应用程序时遇到了某些问题。这是我的代码:
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
public class Login implements ActionListener {
Connection conn1 = null;
Statement stmt1 = null;
Connection conn2 = null;
Statement stmt2 = null;
Connection conn3 = null;
Statement stmt3 = null;
JFrame frame = new JFrame("Login Window");
JPanel startPanel = new JPanel();
JPanel adminPanel = new JPanel();
JPanel engineerPanel = new JPanel();
JButton adminLogin = new JButton("Admin Login");
JButton engineerLogin = new JButton("Engineer Login");
JTextField adminUsername = new JTextField();
JPasswordField adminPassword = new JPasswordField();
JButton adminLog = new JButton("Login");
JButton adminBack = new JButton("Go Back");
JComboBox engineerUsername = new JComboBox();
JPasswordField engineerPassword = new JPasswordField();
JButton engineerLog = new JButton("Login");
JButton engineerBack = new JButton("Go Back");
public Login(){
//Establishing connection with database
conn1 = sqliteConnection.dbConnector();
frame.setLayout(new GridLayout(1, 1));
/*
Setting up the startPanel
*/
startPanel.setLayout(new GridLayout(3, 3, 15, 15));
// Row 1
startPanel.add(new JLabel(" "));
JLabel loginType = new JLabel(" SELECT LOGIN TYPE");
loginType.setFont(new Font("Tahoma", Font.BOLD, 12));
startPanel.add(loginType);
startPanel.add(new JLabel(" "));
// Row 2
startPanel.add(new JLabel(" "));
startPanel.add(adminLogin);
startPanel.add(new JLabel(" "));
// Row 3
startPanel.add(new JLabel(" "));
startPanel.add(engineerLogin);
startPanel.add(new JLabel(" "));
adminLogin.addActionListener(this);
engineerLogin.addActionListener(this);
/*
Setting up adminPanel
*/
adminPanel.setLayout(new GridLayout(4, 2, 15, 15));
// Row 1
adminPanel.add(new JLabel("Admin Login"));
adminPanel.add(new JLabel(" "));
// Row 2
adminPanel.add(new JLabel("Username"));
adminPanel.add(adminUsername);
// Row 3
adminPanel.add(new JLabel("Password"));
adminPanel.add(adminPassword);
// Row 4
adminPanel.add(adminLog);
adminPanel.add(adminBack);
adminLog.addActionListener(this);
adminBack.addActionListener(this);
//Initial Visibility False
adminPanel.setVisible(false);
/*
Setting up engineerPanel
*/
engineerPanel.setLayout(new GridLayout(4, 2, 15, 15));
// Row 1
engineerPanel.add(new JLabel("Engineer Login"));
engineerPanel.add(new JLabel(" "));
// Row 2
try{
Class.forName("org.sqlite.JDBC");
conn1.setAutoCommit(false);
stmt1 = conn1.createStatement();
ResultSet rs1 = stmt1.executeQuery( "SELECT * FROM EngineerData;" );
List<String> engineerNamesList = new ArrayList<String>();
while ( rs1.next() ){
String name = rs1.getString("Name");
engineerNamesList.add(name);
}
// Converting array list to array
String[] engineerNames = new String[engineerNamesList.size()];
engineerNamesList.toArray(engineerNames);
// Adding array into combo-box
for (String en : engineerNames){
engineerUsername.addItem(en);
}
rs1.close();
stmt1.close();
conn1.close();
}
catch ( Exception e1 ) {
JOptionPane.showMessageDialog(null, e1);
}
engineerPanel.add(new JLabel("Engineer Name"));
engineerPanel.add(engineerUsername);
// Row 3
engineerPanel.add(new JLabel("Password"));
engineerPanel.add(engineerPassword);
// Row 4
engineerPanel.add(engineerLog);
engineerPanel.add(engineerBack);
engineerLog.addActionListener(this);
engineerBack.addActionListener(this);
//Initial Visibility False
engineerPanel.setVisible(false);
frame.setSize(500, 200);
frame.setResizable(false);
frame.add(startPanel);
frame.setVisible(true);
}
//Method to convert integar array list to integar array
public int[] convertIntegers(List<Integer> integers)
{
int[] ret = new int[integers.size()];
for (int i=0; i < ret.length; i++)
{
ret[i] = integers.get(i).intValue();
}
return ret;
}
//Admin login method
public void adminLogin(){
String adminUser = adminUsername.getText();
String adminPass = adminPassword.getText();
String adminUserDB = null;
String adminPassDB = null;
conn2 = sqliteConnection.dbConnector();
try{
Class.forName("org.sqlite.JDBC");
conn2.setAutoCommit(false);
stmt2 = conn2.createStatement();
ResultSet rs2 = stmt2.executeQuery( "SELECT * FROM AdminData;" );
adminUserDB = rs2.getString("Username");
adminPassDB = rs2.getString("Password");
conn2.close();
stmt2.close();
rs2.close();
}
catch (Exception e2){
}
if (adminUser.equals(adminUserDB) && adminPass.equals(adminPassDB)){
AdminClass ac = new AdminClass();
frame.dispose();
}
else if (adminUser.equals(adminUserDB) && adminPass != adminPassDB){
JOptionPane.showMessageDialog(null, "Incorrect Password.\nPlease enter again.");
}
else if (adminUser != adminUserDB && adminPass.equals(adminPassDB)){
JOptionPane.showMessageDialog(null, "Incorrect Username.\nPlease enter again.");
}
else if (adminUser != adminUserDB && adminPass != adminPassDB){
JOptionPane.showMessageDialog(null, "Incorrect Username and Password.\nPlease enter again.");
}
}
//Engineer login method
public void engineerLogin(){
String engineerUser = engineerUsername.getSelectedItem().toString();
String engineerPass = engineerPassword.getText();
List<String> engineerNamesList = new ArrayList<String>();
List<String> engineerPasswordsList = new ArrayList<String>();
ArrayList<Integer> uniqueIDList = new ArrayList<Integer>();
conn3 = sqliteConnection.dbConnector();
try{
Class.forName("org.sqlite.JDBC");
conn3.setAutoCommit(false);
stmt3 = conn3.createStatement();
ResultSet rs3 = stmt3.executeQuery( "SELECT * FROM EngineerData;" );
while ( rs3.next() ){
int uniqueId = rs3.getInt("UniqueId");
String engineerUserDB = rs3.getString("Name");
String engineerPassDB = rs3.getString("Password");
//Adding data from database to variables that exist in our code
engineerNamesList.add(engineerUserDB);
engineerPasswordsList.add(engineerPassDB);
uniqueIDList.add(uniqueId);
}
conn3.close();
stmt3.close();
rs3.close();
}
catch (Exception e3){
}
// Creating usable arrays from array lists
String[] engineerNames = new String[engineerNamesList.size()];
engineerNamesList.toArray(engineerNames);
String[] engineerPasswords = new String[engineerPasswordsList.size()];
engineerPasswordsList.toArray(engineerPasswords);
int[] uniqueIDs = convertIntegers(uniqueIDList);
for (int i = 0; i < engineerNames.length; i++){
boolean condition = (engineerUser.equals(engineerNames[i]) && engineerPass.equals(engineerPasswords[i]));
if (condition){
frame.dispose();
EngineerPanel ep = new EngineerPanel();
//This ID is the identifier of the engineer
//This will be used to generate data only for his particular project
ep.setUniqueID(uniqueIDs[i]);
break;
}
else if (i>= 1 && condition != true){
JOptionPane.showMessageDialog(null, "Incorrect Password");
continue;
}
}
}
public void actionPerformed(ActionEvent e){
if (e.getSource() == adminLogin){
startPanel.setVisible(false);
frame.remove(startPanel);
frame.add(adminPanel);
adminPanel.setVisible(true);
}
if (e.getSource() == engineerLogin){
startPanel.setVisible(false);
frame.remove(startPanel);
frame.add(engineerPanel);
engineerPanel.setVisible(true);
}
if (e.getSource() == adminBack){
adminUsername.setText(null);
adminPassword.setText(null);
adminPanel.setVisible(false);
frame.remove(adminPanel);
frame.add(startPanel);
startPanel.setVisible(true);
}
if (e.getSource() == engineerBack){
engineerPassword.setText(null);
engineerPanel.setVisible(false);
frame.remove(engineerPanel);
frame.add(startPanel);
startPanel.setVisible(true);
}
if (e.getSource() == adminLog){
adminLogin();
}
if (e.getSource() == engineerLog){
engineerLogin();
}
}
}
所以你可以看到我正在使用 sqlite 数据库。工程师授权仅适用于第一位工程师,但现在适用于所有工程师。即使数据正确,也说明用户数据不正确。即使我继续单击“确定”,JOptionPane 仍不断弹出。单击几次后,它只会使用下一个 JFrame,尽管它说密码不正确。请帮忙!
最佳答案
如果我理解你的问题,你的逻辑就有缺陷。你这样做:
for (int i = 0; i < engineerNames.length; i++){
boolean condition = ...
if (condition){
// OK
} else {
// show error
}
}
因此,一旦发现输入的信息与数据库行不匹配,就会显示错误。因此,第一个对象的一切都很好,因为第一行将匹配。但对于第二个对象,它将显示错误,因为您已经输入了第二行的数据,而第一行将不匹配。然后你“继续”,这样你就永远不会到达第二个数据库行。你的逻辑应该是:
boolean ok=false;
for (int i = 0; i < engineerNames.length; i++){
boolean condition = ...
ok |= condition;
}
if (ok){
// OK
} else {
// show error
}
ok |= 条件
是一个 OR 运算符:您想要查看是否有任何行匹配。当然,如果 ok 为 true,您可以继续避免查看其他比赛。
但实际上为什么不使用提供的名称和密码进行查询呢?
SELECT * FROM EngineerData where Name=? and Password=?
看看是否得到任何结果。
关于java - SQLite登录授权失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30276456/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!