0

我有一个具有登录名和密码字段的 Jframe 类。登录时,我必须显示登录人的信息,所以我必须从第一个 Jframe 中检索他的登录信息,以便在另一个 Jframe 中进行处理。这是我做的,但登录在第二个 jframe 中返回 NULL:第一个 Jframe(登录名和密码字段):

private void button_connectActionPerformed(java.awt.event.ActionEvent evt) {                                               
    // TODO add your handling code here:
    String x= loginField.getText();
    String y= passwordField.getText();
    AuthentificationDAO authDAO= new AuthentificationDAO();
    boolean ok_login= authDAO.verify_login(x);
    int pass= Integer.parseInt(y);
    System.out.println("password retrieved"+pass);
    boolean ok_pass=authDAO.verify_password(pass);
    System.out.println("ok pass"+ok_pass);
    if (ok_login & ok_pass)
    {
        System.out.println("Login found!");
        Enseignant e= new Enseignant();
      edu.app.persistence.Enseignant ens= new edu.app.persistence.Enseignant(x);
      //ens.setLogin(x);
        System.out.println("login SET:"+ens.getLogin());
        e.setVisible(true);
        this.setVisible(false);


    }
    else {
        System.out.println("Login NOT found!");
        JOptionPane.showMessageDialog(null, "Accourt NOT found. Please check your login or password.", "Check Login/Pass", 1);
    }

第二个 Jframe 将显示该登录信息:

私人无效mauvaisFieldFocusGained(java.awt.event.FocusEvent evt){

edu.app.persistence.Enseignant ens= new edu.app.persistence.Enseignant();
String login=ens.getLogin();
System.out.println("LOGIN EST:"+login);
StatsDAO stats= new StatsDAO();
int id=stats.get_id_from_login(login);
System.out.println("ID="+id);

}

请知道如何解决这个问题?非常感谢。

4

1 回答 1

1

除非ens.loginis static,否则此代码将不起作用。

您可以使用该MVC模式,也可以让您的第二个框架类 extends JFrame,以便向其中添加登录字段。

类似的东西:

    class1 {
        class2 frame2 = new class2();
        void login(){
            String x = loginField.getText();
            edu.app.persist.teach ens= new edu.app.persist.teach(x);
            class2.setLogin(x);
        }
   }

   class2 extends JFrame{
       String login;
       String getLogin(){..}
       void setLogin(String s){..}
       .
       .
   }

我使用了一种伪代码,但它应该足够清楚

于 2012-05-14T11:13:48.870 回答