Перемещение данных текстового поля из класса в другой / проблема при загрузке в БД - PullRequest
0 голосов
/ 08 июня 2018

Я пытаюсь получить данные для имени пользователя, которое используется для входа в мое приложение, чтобы я мог вставить его в БД при создании встречи, чтобы я мог использовать это имя пользователя, чтобы показать все замечания, сделанные этим пользователем, которыезалогинен в приложение.

Это таблица "Programaritest"

ID_programare | Nume | Prenume | Data | Ora | Departament | Doctor | Username | Nr_telefon

Это таблица учетных записей, в которой имя пользователя сохраняется как уникальное

ID_account | Username | Password | Email | Nume |  Prenume | Admin

Здесь используется имя пользователя:

package LicentaApp;



public class LogareController implements Initializable {
 public LoginVerifier loginVerifier = new LoginVerifier();







   @FXML
   private TextField Numeutilzator; Numeutilziator is the username that I am talking about

   @FXML
   private PasswordField Parola;

   @FXML
   private Label Stare;









 @Override
 public void initialize(URL location, ResourceBundle resources) {


  if (loginVerifier.Conexiune()) {
      Stare.setText("");
  } else {

      Stare.setText("Conexiune nereusita!");

  }

 }

 public void Autentificare (ActionEvent event) {
 try {
         if(loginVerifier.testaredate(Numeutilzator.getText(),     Parola.getText())) {
         Stare.setText("Autentificare reusita !");
         ((Node)event.getSource()).getScene().getWindow().hide();
            Stage StagePrincipala= new Stage();
            FXMLLoader incarcator= new FXMLLoader();
            Pane parinte = incarcator.load(getClass().getResource("/LicentaApp/Meniu.fxml").openStream());

            Scene scene = new Scene(parinte);
                scene.getStylesheets().add(getClass().getResource("Style1212.css").toExternalForm());
            StagePrincipala.setScene(scene);
            StagePrincipala.show();

          }
     else { 
         Stare.setText("Nume de utilizator sau parola incorect");

     }




} catch (SQLException e) {





     e.printStackTrace();
} catch (IOException e) {

    e.printStackTrace();
    }
 }
 @FXML
    public void Inregistrare(ActionEvent event) {
        try {
         ((Node)event.getSource()).getScene().getWindow().hide();
            Stage PS= new Stage();
            FXMLLoader incarcator= new FXMLLoader();
            Pane parinte = incarcator.load(getClass().getResource("/LicentaApp/InregistrareUser.fxml").openStream());
            Scene scena = new Scene(parinte);
            scena.getStylesheets().add(getClass().getResource("Style1212.css").toExternalForm());
            PS.setScene(scena);
            PS.show();
    } catch (Exception e) {

    }

*Here I m calling the function that I made in AddProgramareController and 
passing it the username located in Numeutilzator*

@FXML 
 public void GetUsername() {
     try {
     FXMLLoader loader=new     FXMLLoader(getClass().getResource("/LicentaApp/AddProgramare.fxml"));
     Parent root = (Parent) loader.load();

     AddProgramareController AddPr=loader.getController();
     AddPr.MyUsername(Numeutilzator.getText());


 } catch (IOException e) {
     e.printStackTrace();
 }
 }

}
}
     ***THis is where I save the username so I can use it to add it into the     db***  

Здесь я пытаюсь добавить точку, а также данные, которые яПолучение через FXML Я пытаюсь добавить имя пользователя в таблицу, а также

package LicentaApp;



public class AddProgramareController implements Initializable {
    ObservableList Timestamp=FXCollections.observableArrayList();




@FXML
private TextField Nume;

@FXML
private TextField Prenume;

@FXML
private TextField Ora;

@FXML
private DatePicker Data;

@FXML
private TextField Departament;

@FXML
private TextField Doctor;

@FXML
private TextField Nr_telefon;

@FXML
private TextField Numeutilizator;













public void initialize(URL location, ResourceBundle resources) {

} 

*Here's the function that I'll call in GetUsername from LogareController
 public void MyUsername(String Numeutilizator) {
    this.Numeutilizator.setText(Numeutilizator);

}

@FXML 
private void AddProgramare(ActionEvent event) throws SQLException, IOException  {


    String Interogare1= "INSERT INTO programaritest(Nume,Prenume,Data,Ora,Departament,Doctor,Nr_telefon,Numeutilizator) VALUES(?,?,?,?,?,?,?,?)";

    String nume=Nume.getText();
    String prenume=Prenume.getText();

    LocalDate data=Data.getValue(); 

    String ora=Ora.getText();
    String departament=Departament.getText();
    String doctor=Doctor.getText();
    String nr_telefon=Nr_telefon.getText();
    String numeutilizator=Numeutilizator.getText();

    try {
        ConectaredB ConectaredB=new ConectaredB();
        Connection conexiune=ConectaredB.logareDB();
        PreparedStatement MG = conexiune.prepareStatement(Interogare1);


        MG.setString(1, nume);
        MG.setString(2, prenume);
        MG.setDate(3, Date.valueOf(data)); 
        MG.setString(4, ora);
        MG.setString(5, departament);
        MG.setString(6, doctor);
        MG.setString(7, nr_telefon);
        MG.setString(8, numeutilizator);

        MG.executeUpdate();

        // ...
   } catch (SQLException exceptie1) {
       exceptie1.printStackTrace(); 
   }


}
}

Сообщение об ошибке, которое я получаю при попытке добавить новую встречу:

Вызывается: java.lang.NullPointerException в LicentaApp.AddProgramareController.AddProgramare (AddProgramareController.java:103)

В строке 103: Строка числитель = = Нумеутилизатор.getText (10) 30 ();* Похоже, по какой-то причине он все еще не загружает имя пользователя.

Так что, в принципе, либо способ, которым я получаю имя пользователя для вставки его в БД, неверен, либо фактически вставка неверна.

1 Ответ

0 голосов
/ 08 июня 2018

Ошибка в вашем getText method в class LogareController.

У вас есть следующее:

public String getText() {
    TextField Numeutilizator = new TextField();
    Numeutilizator.getText();
    return null;
}

Вы всегда возвращаете нуль вместо текста в вашемтекстовое поле.Вы также воссоздаете переменную Numeutilizator локально в методе, который всегда будет пустым.Вы должны использовать тот, который вы определили в начале вашего класса вместо этого.Я считаю, что изменение метода getText на следующее должно исправить ваши ошибки:

public String getText() {
    return this.Numeutilizator.getText();
}

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...