Как заполнить таблицу JavaFX для TCP-клиента с TCP-сервера, который извлекает данные из БД - PullRequest
0 голосов
/ 03 июня 2018

Моя задача - отправлять данные от клиента через сервер в базу данных, получать эти данные через сервер и заполнять некоторые таблицы.

Я не могу найти способ заполнить эти таблицы вкак я хочу.

Проект GitHub ссылка .

Клиентский прослушиватель, откуда я получаю данные для клиента

public clientListener(TextArea textArea) {
        this.textArea = textArea;
        int portNr = Integer.parseInt(port);

        try {
            // Create a socket to connect to the server
            @SuppressWarnings("resource")
            Socket socket = new Socket("localhost", portNr);

            // Create an output stream to send data to the server
            outputToServer = new PrintWriter(socket.getOutputStream());

            // Create an input stream to read data from the server
            inputFromServer = new BufferedReader(new 
            InputStreamReader(socket.getInputStream()));

        } catch (IOException ex) {
            Platform.runLater(() -> textArea.appendText("Exception in gateway constructor: " + ex.toString() + "\n"));
        }
    } 

    public ObservableList<Qyteti> getQytet() {
        outputToServer.println(GET_QYTET);
        outputToServer.flush();
        String ID = null, Qyteti = null, ZIP = null;
        try {
            ObservableList<Qyteti> Qytet = null;
            Qytet.add(new Qyteti(inputFromServer.readLine().concat(ID), 
            inputFromServer.readLine().concat(Qyteti), 
            inputFromServer.readLine().concat(ZIP)));
            return Qytet;
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            return null;
        }
    }

Контроллер форм

public void updateTable() {
    ID.setCellValueFactory(new PropertyValueFactory<>("ID"));
    Qyteti.setCellValueFactory(new PropertyValueFactory<>("Qyteti"));
    ZIP.setCellValueFactory(new PropertyValueFactory<>("ZIP"));
    QytetiList.add((application.Qyteti) gateway.getQytet());    
    tblQyteti.setItems(QytetiList);
}

Функции сервера, откуда в разных случаях я получаю разные результаты

public void run() {
    handler = new ConnectionHandler();
    try {
    // Create reading and writing streams
    BufferedReader inputFromClient = new BufferedReader(new 
    InputStreamReader(socket.getInputStream()));
    PrintWriter outputToClient = new PrintWriter(socket.getOutputStream());

    // Continuously serve the client
    while (true) {
      // Receive request code from the client
      int request = Integer.parseInt(inputFromClient.readLine());
      // Process request
      switch(request) {
          case GET_QYTET: {
              connection = handler.getConnection();
              String merrQytet = "SELECT * FROM tblQyteti";
              try {
                  pst = connection.prepareStatement(merrQytet);
                  ResultSet rs = pst.executeQuery();
                  while(rs.next()) { 
                    outputToClient.printf(merrQytet, rs.getString("qid"), rs.getString("Qyteti"), rs.getString("ZIP"));
                  }
              } catch (SQLException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
          }
      }
    }
  }
  catch(IOException ex) {
        Platform.runLater(()->textArea.appendText("Exception in client 
        thread: "+ex.toString()+"\n"));
  }

Класс Qyteti, который используется как тип объекта:

import java.io.Serializable;

public class Qyteti implements Serializable{
    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    String ID, Qyteti, ZIP;

    public Qyteti(String ID, String Qyteti, String ZIP) {
        this.ID = ID;
        this.Qyteti = Qyteti;
        this.ZIP = ZIP;
    }

    public String getID() {
        return ID;
    }

    public void setID(String iD) {
        ID = iD;
    }

    public String getQyteti() {
        return Qyteti;
    }

    public void setQyteti(String qyteti) {
        Qyteti = qyteti;
    }

    public String getZIP() {
        return ZIP;
    }

    public void setZIP(String zIP) {
        ZIP = zIP;
    }


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