M
Mister9222. Mai 2017 10:17

Клиент серверное приложение "удаленный проводник"

Всем привет. Нужна помощь в оформлении запроса и ответа клиента и сервера. Все делается под линукс. Соединение между клиентом и сервером есть. Знаю что нужно использовать для просмота и скачивания данных классы qdir и qfile. Честно говоря я на самом деле далек от этого... Очень нужна помощь. Парни выручайте.

provodnik.txt
Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

7
Evgenii Legotckoi
  • 23. Mai 2017 02:31

День добрый. Я так понимаю, что это код сервера и клиента. Они на данный момент работают? У вас получилось передать какую-нибудь текстовую информацию?

У вас сейчас получается следующий список задач:

  1. Сделать навигацию по каталогам
  2. Получить список файлов в текущем каталоге
  3. Реализовать скачивание файлов

Поэтому давайте по порядку.

Навигацию по каталогам нужно реализовывать с помощью QDir, но для передачи информации нужно оформить запросы. Как у вас обстоят дела с пониманием JSON?

    M
    • 23. Mai 2017 02:37

    Да, этот код рабочий. А с JSON не знаком (

      Evgenii Legotckoi
      • 23. Mai 2017 02:42

      Я про JSON сказал для того, что Вам придётся передавать информацию с сервера на клиента и наоборот. Эту информацию нужно как-то организовывать. Обычно берут или XML или JSON. Я предпочитаю JSON

      Посмотрите статью про JSON для начала, чтобы ознакомиться с ним.

        M
        • 23. Mai 2017 02:56

        Спасибо. Я посмотрю. А вот вообще как должен выглядеть запрос и ответ по моей теме.. Я не могу толком сообразить (

          M
          • 23. Mai 2017 17:07

          Как составить грамотно запрос чтобы сервер отобразил файлы клиенту?

            Evgenii Legotckoi
            • 24. Mai 2017 02:59

            Чтобы сделать всё грамотно, придётся потратить достаточно много времени (Разработка архитектуры программы - это процесс длительный), но идею я Вам сейчас подкину.

            Начнём с сервера

            mainwindow.h

            #ifndef MAINWINDOW_H
            #define MAINWINDOW_H
            
            #include <QMainWindow>
            #include <QTcpServer>
            #include <QTcpSocket>
            
            namespace Ui {
            class MainWindow;
            }
            
            class MainWindow : public QMainWindow
            {
                Q_OBJECT
            
            public:
                explicit MainWindow(QWidget *parent = 0);
                ~MainWindow();
            
            public slots:
                void newConnection();
                void serverRead();
                void slotClientDisconnected();
            
            private:
                Ui::MainWindow *ui;
                QTcpServer *m_server;
                QTcpSocket *m_socket;
            };
            
            #endif // MAINWINDOW_H
            

            mainwindow.cpp

            #include "mainwindow.h"
            #include "ui_mainwindow.h"
            
            #include <QDebug>
            #include <QDir>
            
            MainWindow::MainWindow(QWidget *parent) :
                QMainWindow(parent),
                ui(new Ui::MainWindow)
            {
                ui->setupUi(this);
            
                m_server = new QTcpServer(this);
            
                connect(m_server, &QTcpServer::newConnection, this, &MainWindow::newConnection);
            
                if(!m_server->listen(QHostAddress::Any, 7777)){
                    qDebug() << "server is not started";
                } else {
                    qDebug() << "server is started";
                }
            }
            
            MainWindow::~MainWindow()
            {
                delete ui;
            }
            
            void MainWindow::newConnection()
            {
                m_socket = m_server->nextPendingConnection();
            
                connect(m_socket, &QTcpSocket::readyRead, this, &MainWindow::serverRead);
                connect(m_socket, &QTcpSocket::disconnected, this, &MainWindow::slotClientDisconnected);
            }
            
            void MainWindow::serverRead()
            {
                while(m_socket->bytesAvailable() > 0)
                {
                    QByteArray array = m_socket->readAll();
                    // Допустим, получили команду, которая выглядит как "Get Paths"
                    if (QString(array) == "Get Paths")
                    {
                        // Если получили такую команду, то попробуем выдать список того, что содержится в домашнем каталоге
                        for (QString filePath : QDir::home().entryList())
                        {
                            m_socket->write(QString(filePath + "\n").toUtf8());
                        }
                    }
                    else
                    {
                        m_socket->write("No");
                    }
                }
            }
            
            void MainWindow::slotClientDisconnected()
            {
                m_socket->close();
            }
            

            А теперь по клиенту. Тут удобно будет выделить отдельный класс под клиента.

            client.h

            #ifndef CLIENT_H
            #define CLIENT_H
            
            #include <QObject>
            #include <QTcpSocket>
            
            class Client : public QObject
            {
                Q_OBJECT
            public:
                explicit Client(QObject *parent = 0);
            
            signals:
                void readyRead(QByteArray data);
            
            public slots:
                bool connectToHost();
                bool writeData(QByteArray data);
                void readFromSocket();
            
            private:
                QTcpSocket* m_socket;
            };
            
            #endif // CLIENT_H
            

            client.cpp

            #include "client.h"
            
            #include <QDebug>
            
            Client::Client(QObject *parent) : QObject(parent)
            {
                m_socket = new QTcpSocket(this);
                connect(m_socket, &QTcpSocket::readyRead, this, &Client::readFromSocket);
            }
            
            bool Client::connectToHost()
            {
                m_socket->connectToHost("127.0.0.1", 7777);
                return m_socket->waitForConnected();
            }
            
            bool Client::writeData(QByteArray data)
            {
                m_socket->write(data);
                return m_socket->waitForBytesWritten();
            }
            
            void Client::readFromSocket()
            {
                emit readyRead(m_socket->readAll());
            }

            И посмотрим, как эта увязка может выглядеть в самом окне клиентского приложения

            mainwindow.h

            #ifndef MAINWINDOW_H
            #define MAINWINDOW_H
            
            #include <QMainWindow>
            #include "client.h"
            
            namespace Ui {
            class MainWindow;
            }
            
            class MainWindow : public QMainWindow
            {
                Q_OBJECT
            
            public:
                explicit MainWindow(QWidget *parent = 0);
                ~MainWindow();
            
            private slots:
                void on_pushButton_clicked();
                void readyRead(QByteArray array);
            
            private:
                Ui::MainWindow *ui;
                Client *m_client;
            };
            
            #endif // MAINWINDOW_H
            

            mainwindow.cpp

            #include "mainwindow.h"
            #include "ui_mainwindow.h"
            
            MainWindow::MainWindow(QWidget *parent) :
                QMainWindow(parent),
                ui(new Ui::MainWindow)
            {
                ui->setupUi(this);
                m_client = new Client(this);
                connect(m_client, &Client::readyRead, this, &MainWindow::readyRead);
            }
            
            MainWindow::~MainWindow()
            {
                delete ui;
            }
            
            void MainWindow::on_pushButton_clicked()
            {
                m_client->connectToHost();
                m_client->writeData("Get Paths");
            }
            
            void MainWindow::readyRead(QByteArray array)
            {
                ui->plainTextEdit->appendPlainText(array);
            }
            

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

              M
              • 24. Mai 2017 06:29

              Благодарю за пример.

                Kommentare

                Nur autorisierte Benutzer können Kommentare posten.
                Bitte Anmelden oder Registrieren
                Letzte Kommentare
                A
                ALO1ZE19. Oktober 2024 18:19
                Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                ИМ
                Игорь Максимов5. Oktober 2024 17:51
                Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                d
                dblas55. Juli 2024 21:02
                QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                k
                kmssr9. Februar 2024 05:43
                Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                Jetzt im Forum diskutieren
                J
                JacobFib17. Oktober 2024 13:27
                добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                JW
                Jhon Wick2. Oktober 2024 01:52
                Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
                КГ
                Кирилл Гусарев27. September 2024 19:09
                Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
                F
                Fynjy22. Juli 2024 14:15
                при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                Folgen Sie uns in sozialen Netzwerken