Отправка данных JTable с сервера на клиент JTable через сокеты - PullRequest
0 голосов
/ 01 июня 2018

У меня есть JTable в форме SERVER, он заполняется из базы данных MySQL, закодирован в конструкторе:

String sql = "SELECT * from fiekorari";
        try{
        pst=conn.prepareStatement(sql);
        res=pst.executeQuery();
        table.setModel(DbUtils.resultSetToTableModel(res));
        pst.close();
        res.close();
        } catch (SQLException e1){
            e1.printStackTrace();
        }

Соединение установлено на главном с использованием TCP-соединения, СТОРОНА СЕРВЕРА:

public class Serveri extends JFrame {

    private JPanel contentPane;
    static ServerSocket ss;
    static Socket s;
    static DataInputStream din;
    static DataOutputStream dout;
    private JTextField txtMesazhi;
    private static JTextArea txtA;
    static Connection conn=null;
    static ResultSet res= null;
    static PreparedStatement pst = null;
    private Object id;


    /**
     * Launch the application.
     */
    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {
            public void run() {
                try {
                    Serveri frame = new Serveri();
                    frame.setVisible(true);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        });
        SqlConn.getConnection();
        String msgin="";
        try 
        {
            ss=new ServerSocket(1201);
            s=ss.accept();
            din=new DataInputStream(s.getInputStream());
            dout=new DataOutputStream(s.getOutputStream()); //code continues with chat programming

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

Ниже приведен код на стороне Клиента, который устанавливает соединение через TCP для чата, но теперь не нужно добавлять таблицу, которая считывает данные из таблицы серверов через сокеты:

public class Klienti extends JFrame {

    private JPanel contentPane;
    private JTextField txtMesazhi;
    private static JTextArea txtShfaq1;
    static Socket s;
    static DataInputStream din;
    static DataOutputStream dout;
    private JButton btnNewButton;
    public static String sql1;
    private JTable table;
    private JTextField txtEmri;
    private JTextField txtMbiemri;
    private JTextField txtOra;
    static Connection conn=null;
    static ResultSet res= null;
    static PreparedStatement pst = null;
     private Pattern pattern;
     private Matcher matcher;
     private String loc;



    /**
     * Launch the application.
     */
    public static void main(String[] args) {
        EventQueue.invokeLater(new Runnable() {
            public void run() {
                try {
                    Klienti frame = new Klienti();
                    frame.setVisible(true);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        });
        //SqlConn.getConnection();
        try 
        {
            s=new Socket("localhost",1201);
            din=new DataInputStream(s.getInputStream());
            dout=new DataOutputStream(s.getOutputStream());

//code in constructor Client side which sends text message to Server through sockets: 

dout.writeUTF(msgout);
            txtShfaq1.setText(txtShfaq1.getText().trim()+"\nJu:\t"+msgout);
            txt.setText("");

1 Ответ

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

Нет, вам не следует отправлять JTable с сервера на клиент.На самом деле сервер не должен иметь никакого компонента свинга.Он должен просто извлекать данные по запросу и отправлять только данные в подходящем формате, не обернутом в JTable.

Еще один момент, насколько это возможно, не осуществлять простую связь через сокет.Используйте протокол более высокого уровня, такой как HTTP.Сервер может запускать веб-службу http и предоставлять данные в формате json, xml.

Клиент может использовать любой из множества доступных клиентов http для получения данных с сервера.Эти библиотеки позаботились о многих проблемах с сокетами.

...