Слушатель действий моей программы не будет работать - PullRequest
0 голосов
/ 13 июля 2011

Это снова я, и я просто не могу заставить этот код работать.Я в основном прошу совета, почему кнопка ничего не делает при нажатии.Вы хотите, чтобы я прикрепил исходный код?

Метод, который я пытаюсь реализовать:

   public static void UserInput() {
      try {
         stmt = connect.createStatement();
         ResultSet res = stmt.executeQuery("SELECT * FROM " + tableName);
         while (res.next()) {
            if (res.getString("Username").equals(usernameField.getText())) {
               if (res.getString("Password").equals(passwordField.getPassword())) {
                  JOptionPane.showMessageDialog(null, "Correct", "Correct",
                           JOptionPane.INFORMATION_MESSAGE);
               } else {
                  JOptionPane.showMessageDialog(null, "Error. Incorrect "
                           + "username or password.", "Error",
                           JOptionPane.ERROR_MESSAGE);
               }
            } else {
               JOptionPane.showMessageDialog(null, "Error. Incorrect "
                        + "username or password.", "Error",
                        JOptionPane.ERROR_MESSAGE);
            }
         }
         res.close();
         stmt.close();
         connect.close();

      } catch (SQLException sqlExcept) {
         sqlExcept.printStackTrace();
      }

   }

И вот как я его называю:

             if(firstTime == false) {
              JavaDB jdb = new JavaDB();
         }

        JavaDB window = new JavaDB("");
        window.addWindowListener(new WindowAdapter(){
            public void windowClosing(WindowEvent e){
                    System.exit(0);
                }
            });
        }

А вот actionListner:

            submit = new JButton("Submit");
            c.add(submit);
              submit.addActionListener( new ActionListener() {  
                    public void actionPerformed( ActionEvent e ) { 
                      if(e.getSource().equals(submit)) {
                         UserInput();
            }
         }  
     });  ;        

Если вам нужно больше, дайте мне знать.Я учу себя Java, и я не знаю, чему учиться, поэтому любые советы будут приветствоваться.Я также новичок в переполнении стека и размещении кода, поэтому любая вещь, которую вы можете дать мне, будет более чем оценена.Заранее спасибо.

Редактирование: теперь я добавил класс для обработки событий с потоком внутри него, вот так;

             public class ButtonHandler implements ActionListener{
    public void actionPerformed(ActionEvent e){
        if(e.getSource().equals(submit)){
            Thread th = new Thread(new JavaDB());
            th.start();
            th.run();
            try {
                th.wait();
            } catch (InterruptedException e1) {
            }
        }
        else{
        System.exit(0);
        }   
    }

И я изменил UserInput на run ().Однако теперь, когда я нажимаю кнопку отправки, GUI исчезает.Просто для справки, которая вам может понадобиться, вот мой основной метод:

             public static void main(String args[]) throws SQLException,
        InterruptedException {
    createConnection();
    boolean firstTime = firstTime();
    if (firstTime) {
        JavaDB db = new JavaDB("");
        db.createAccount();
        try {
            connect = DriverManager
                    .getConnection("jdbc:derby:\\KeithDB;shutdown=true");
        } catch (SQLException XJ015) {
        }
    }
    if (firstTime == false) {
        JavaDB jdb = new JavaDB();
        Thread th = new Thread();
    }

    JavaDB window = new JavaDB("");
    window.addWindowListener(new WindowAdapter() {
        public void windowClosing(WindowEvent e) {
            System.exit(0);
        }
    });
}

Что-нибудь еще, что вам нужно, дайте мне знать

Ответы [ 2 ]

1 голос
/ 15 июля 2011

Я наконец получил его на работу!У меня был другой конструктор с теми же именами переменных, и мой вызов JTextFields был ошибочно принят за вызов другого конструктора.Заявления foo действительно помогли !!!Спасибо всем!

1 голос
/ 13 июля 2011

PasswordDemo, как показано в Как использовать поля пароля , было бы хорошей отправной точкой для вашего исследования, и это сделало бы эффективную sscce .

Приложение: В отсутствие полного примера или сведений о том, какую базу данных вы используете, я получил следующий результат,

Version: H2 1.3.157 (2011-06-25) 1.3

, запустив следующую модификацию PasswordDemo против База данных H2 :

if (isPasswordCorrect(input)) {
    try {
        Connection conn = DriverManager.getConnection(
            "jdbc:h2:mem:", "sa", "secret");
        DatabaseMetaData metaData = conn.getMetaData();
        System.out.println("Version:"
            + " " + metaData.getDatabaseProductName()
            + " " + metaData.getDatabaseProductVersion()
            + " " + metaData.getDatabaseMajorVersion()
            + "." + metaData.getDatabaseMinorVersion());
    } catch (SQLException ex) {
        ex.printStackTrace(System.err);
    }
} ...

Приложение: я получил следующий результат,

Version: Apache Derby 10.6.2.1 - (999685) 10.6

, выполнив следующую модификацию для PasswordDemo против Apache Derby :

if (isPasswordCorrect(input)) {
    try {
        EmbeddedDataSource ds = new EmbeddedDataSource();
        ds.setDatabaseName("/home/trashgod/.netbeans-derby/dbtest");
        Connection conn = ds.getConnection("sa", "secret");
        DatabaseMetaData metaData = conn.getMetaData();
        System.out.println("Version:"
            + " " + metaData.getDatabaseProductName()
            + " " + metaData.getDatabaseProductVersion()
            + " " + metaData.getDatabaseMajorVersion()
            + "." + metaData.getDatabaseMinorVersion());
    } catch (SQLException ex) {
        ex.printStackTrace(System.err);
    }
} ...
...