Михаиллл
May 9, 2019, 10:33 p.m.

Как в Qt сделать API?

API

Добрый день.
У меня есть база данных PostgreSQL.
Название "test_db"
У нее 3 столбца: "id", "int", "text".
Создал приложение, которое подключаеться к этой базе данных.
Как из этого приложения сделать API? К примеру отправлять данные из ячейки столбца "text" нужной строчки.

4

Do you like it? Share on social networks!

14
ЧГ
  • May 10, 2019, 1 a.m.

Смотря куда отправлять. Если другому приложению то через локальные сокеты (QLocalSocket), или по сети. В любом случае, данные в вашем приложении кладуться в QDataStream и пересылаются. Ну это как я понял вопрос, можете поподробнее объяснить?

    Evgenii Legotckoi
    • May 10, 2019, 2:21 p.m.

    Добрый день.

    А давайте вы подробнее раскажете, что именно хотите сделать. Просто делать API для приложений на Qt да и вообще на C++ не самая лучшая идея на мой взгляд. Не в том плане, что это плохо, а в том плане, что делать подобное в одиночку - это очень большие трудозатраты, которые очень медленно окупаются. Я бы и 10-й части не сделал из того, что сейчас есть на сайте, если бы писал его бэкенд на C++.

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

      Михаиллл
      • May 10, 2019, 2:28 p.m.

      Добрый день.
      Просто хочу изучить технологию создания API и работы с ним.
      Какие наиоболее оптимальные варианты для создания API?

        Evgenii Legotckoi
        • May 10, 2019, 2:37 p.m.

        Вариантов, как реализовать это всё - уйма. Да и самих API также очень много. Сейчас наиболее распространён, на мой взгляд, вариант REST API. Вот небольшая обзорная статья на эту тему. Собственно говоря, если делать API на C++, то я бы посмотрел в сторону Wt фреймворка, там уже давно должны быть необходимые механизмы. А вот Qt для этого подходит меньше.

        Но на данный момемнт я бы склонялся к тому, чтобы взять django и django-rest-framework, ну или аналог из других технологических стеков, думаю, что в Ruby on Rails также есть что-то подобное.

        REST-API - это в первую очередь WEB, так что и технологии стоит брать соответсвующие. Если только не рассматриваете вариант добавления REST-API во встраиваемое решение. Тут конечно будете ограничены набором языков программирования

          Михаиллл
          • May 10, 2019, 5:05 p.m.

          А если это не веб, а андроид или ios? Что лучше для этого?

            Evgenii Legotckoi
            • May 10, 2019, 5:17 p.m.

            Android и iOS - это клиентские приложения. А я говорил в первую очередь про бэкенд, про сервер с базой данных и т.д.

            Для Android и iOS можете писать на Qt/QML/C++ или Dart/Flutter или на иной любой технологии, что удобнее, в том числе и на нативных Java и Swift.

            Но для самого сервера, который предоставляет API для получения данных, конечно нужно выбирать то, что будет наиболее удобным и быстро реализуемым. Для сервера на данный момент существует множество решений, которые позволяют быстро разрабатывать API и структуру базы данных. Я могу лишь со стороны своего опыта посоветовать Django, возможно, что кто-то посоветует вам NodeJS и Ruby on Rails. Я просто не стал бы заморчиваться с C++ для этого. Много мороки будет.

            В любом случае будет лучше, если вы используете существующие решения для реализации транспортного и уровня приложения в стеке OSI. А это уже скорее всего будет HTTP/HTTPS, а значит стоит посмотреть в сторону REST-API. В таком случае у вас сервер уже будет доступен через WEB протоколы.

            Когда начну писать приложение для сайта, если такой момент когда-нибудь настанет, то продолжу использовать Django, а клиентские приложения будут писать на какой-нибудь свежей технологии, может на Dart/Flutter, ну и или на Qt, посмотрю в каком он будет состоянии на тот момент.

            То есть серверу поровну, что будет к нему подключаться, Android, iOS или десктопное приложение. Говоря Web сервер я не имею ввиду только сервер, который отдаёт странички. Это может быть и просто узел в сети интернет, который предоставляет REST-API.

              Михаиллл
              • May 10, 2019, 5:21 p.m.
              • The answer was marked as a solution.

              Спасибо

                Михаиллл
                • May 31, 2019, 11:37 p.m.

                Скажите пожалуйста, нет ли у вас примера построения API на Django?

                  Evgenii Legotckoi
                  • June 4, 2019, 4:06 p.m.

                  Не было необходимости много заниматься этим, поэтому могу посоветовать почитать документацию на django_rest_framework - это то, что нужно

                    Михаиллл
                    • June 15, 2019, 2:55 p.m.

                    В какой среде разработки удобней писать на django? Подходит ли для этого и добен ли PyQT5?

                      Evgenii Legotckoi
                      • June 17, 2019, 1:39 a.m.

                      PyQt5 - это не среда разработки. Это библиотека привязок на python к библиотеки Qt.

                      Для разработки на Django я использую PyCharm Professional Edition.

                        Михаиллл
                        • June 17, 2019, 11:08 a.m.

                        Спасибо.
                        А бесплатный PyCharm подойдет?

                          Evgenii Legotckoi
                          • June 17, 2019, 11:11 a.m.

                          Нет. В PyCharm Community Edition нет поддержки Django. Разрабатывать конечно можно, только запускать всё вручную из консоли придётся.

                          Можете также поискать в интернете ключи или бэкдор сервера, но их довольно быстро блочат в JetBrains. Поэтому я использую Proffesional Edition.

                            Михаиллл
                            • June 17, 2019, 11:47 a.m.

                            Пасибо.

                              Comments

                              Only authorized users can post comments.
                              Please, Log in or Sign up
                              • Last comments
                              • Evgenii Legotckoi
                                April 16, 2025, 5:08 p.m.
                                Благодарю за отзыв. И вам желаю всяческих успехов!
                              • IscanderChe
                                April 12, 2025, 5:12 p.m.
                                Добрый день. Спасибо Вам за этот проект и отдельно за ответы на форуме, которые мне очень помогли в некоммерческих пет-проектах. Профессиональным программистом я так и не стал, но узнал мно…
                              • AK
                                April 1, 2025, 11:41 a.m.
                                Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
                              • Evgenii Legotckoi
                                March 9, 2025, 9:02 p.m.
                                К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
                              • VP
                                March 9, 2025, 4:14 p.m.
                                Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…