M
Mister9222 мая 2017 г. 20:17

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

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

provodnik.txt
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

7
Evgenii Legotckoi
  • 23 мая 2017 г. 12:31

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

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

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

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

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

    M
    • 23 мая 2017 г. 12:37

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

      Evgenii Legotckoi
      • 23 мая 2017 г. 12:42

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

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

        M
        • 23 мая 2017 г. 12:56

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

          M
          • 24 мая 2017 г. 3:07

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

            Evgenii Legotckoi
            • 24 мая 2017 г. 12: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 мая 2017 г. 16:29

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

                Комментарии

                Только авторизованные пользователи могут публиковать комментарии.
                Пожалуйста, авторизуйтесь или зарегистрируйтесь
                Ua

                Qt - Тест 001. Сигналы и слоты

                • Результат:84баллов,
                • Очки рейтинга4
                Ua

                Qt - Тест 001. Сигналы и слоты

                • Результат:42баллов,
                • Очки рейтинга-8
                ОК

                Qt - Тест 001. Сигналы и слоты

                • Результат:47баллов,
                • Очки рейтинга-6
                Последние комментарии
                ИМ
                Игорь Максимов22 ноября 2024 г. 21:51
                Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                Evgenii Legotckoi
                Evgenii Legotckoi31 октября 2024 г. 23:37
                Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                A
                ALO1ZE19 октября 2024 г. 17:19
                Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                ИМ
                Игорь Максимов5 октября 2024 г. 16:51
                Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                d
                dblas55 июля 2024 г. 20:02
                QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                Сейчас обсуждают на форуме
                f
                firstlunoxod15 февраля 2025 г. 13:46
                Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
                Дмитрий
                Дмитрий3 февраля 2025 г. 16:24
                Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
                NW
                Nayo Wai30 января 2025 г. 19:22
                не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
                n
                nkly3 января 2025 г. 12:52
                Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
                M
                Marsel17 августа 2023 г. 0:26
                OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

                Следите за нами в социальных сетях