© EVILEG 2015-2018
Рекомендует хостинг
TIMEWEB
24 июля 2018 г. 8:52

Qt Android. POST запросы, как отправить и принять

Добрый день) Столкнулся с такой ситуацией. Нужно отправить HTTP запрос используя POST запрос. Написал маленький код в посмотрев видео урок про QNetworkAccessMeneger.Но запрос идет но обратно ничего не получаю. Точнее получаю пустой файл.
Там только был пример про скачивания файла с помощи GET запроса.


Можете пожалуйста написать маленький код на тему как отправить и принять POST запрос. Буду очень благодарен)

  • #
  • 24 июля 2018 г. 10:37

Я разобрался) Слепил и она рабоnает. Отправляет, это хорошо. Но есть одно маленькое но ....не знаю как получить header ответа POST


database.h


#ifndef DATABASE_H
#define DATABASE_H
#include <QObject>
#include <QDebug>
#include <QGuiApplication>
#include <QQuickView>
#include <QQmlContext>
#include <QDebug>
#include <QtSql>
#include "QtSql/QSqlDatabase"
#include "QSqlQuery"
#include <QNetworkAccessManager>
#include <QNetworkRequest>
#include <QNetworkReply>

class database: public QObject
{
    Q_OBJECT

    Q_PROPERTY(QString myMail      READ  getSomePropertyMail       WRITE setSomePropertyMail       NOTIFY  sendToMail)     //Для обменна даными о пройденном пути
    Q_PROPERTY(QString myPassword  READ  getSomePropertyPassword   WRITE setSomePropertyPassword   NOTIFY  sendToPassword)     //Для обменна даными о времени записи трека

public:
    explicit database(QObject *parent = 0);

    QString getSomePropertyMail()const;                                                         //Для обменна даными о времени t
    void    setSomePropertyMail(const QString &);                                                  //Для обменна даными о времени t

    QString getSomePropertyPassword()const;                                                          //Для обменна даными о расстоянии m
    void    setSomePropertyPassword(const QString &);                                                   //Для обменна даными о расстоянии m

signals:
    void finished();
    void sendToMail(QString);                                                                    //Сигналы для передачи пути
    void sendToPassword(QString);                                                                   //Сигналы для передачи данных о времени
    void readyRead();

public slots:

    void getReplyFinished();
    void open_users();
    void readyReadReply();

private:
    QSqlDatabase            db;
    QString                 myMail;
    QString                 myPassword;
    QNetworkAccessManager   manager;
    QNetworkReply           *reply;
    QUrl                    apiUrl;
    QByteArray              requestString;

};

#endif

database.cpp
#include "database.h"
#include <QObject>
#include <QNetworkAccessManager>
#include <QNetworkRequest>
#include <QNetworkReply>
#include <QFile>
#include <QUrl>
#include <QDebug>
#include <QHttpPart>
#include <QByteArray>
#include <QObject>
#include <QDebug>
#include <QTime>
#include "QtSql/QSqlDatabase"
#include <QtSql/QSql>
#include <QtSql/QSqlDatabase>
#include <QtSql/QSqlQuery>
#include <QTime>
#include <QLocale>
#include <QDateTime>
#include <QtMath>
#include "QSqlQuery"
#include <QtSql>

database::database(QObject *parent): QObject(parent)
{

}

void database::setSomePropertyMail(const QString &i)                                      //Для обменна даными с переменной way
{
    myMail = i;
    emit sendToMail(myMail);
}

QString database::getSomePropertyMail()const                                              //Для обменна даными с переменной way
{
    return myMail;
}

void database::setSomePropertyPassword (const QString &i)                                     //Для обменна даными с переменной time
{
    myPassword = i;
    emit sendToPassword(myPassword);
}

QString database::getSomePropertyPassword()const                                             //Для обменна даными с переменной time
{
    return myPassword;
}

void database::open_users()
{
    qDebug()<<"Прошел"<<endl;
    apiUrl =  "https://******************";
    requestString = "*********************";

    QNetworkRequest request(apiUrl);
   qDebug()<<"Прошел"<<endl;
    request.setHeader(QNetworkRequest::ContentTypeHeader,QVariant("application/x-www-form-urlencoded"));
    qDebug()<<"Прошел"<<endl;
    reply = manager.post(request, requestString);

    connect(reply, SIGNAL(finished()),this, SLOT(getReplyFinished()));
    connect(reply, SIGNAL(finished()), this, SLOT(readyReadReply()));
}
void database::getReplyFinished(){
    reply->deleteLater();
}

void database::readyReadReply(){
   QString answer = QString::fromUtf8(reply->readAll());
   qDebug()<<"Прошел1"<<endl;
   qDebug()<<answer<<endl;
   qDebug()<<"Прошел1"<<endl;
}

  • #
  • 24 июля 2018 г. 10:39

результат компиляции

Добрый день!

Поздравляю с решением проблемы.
Что касается заголовка, то QNetworkReply имеет методы
  • header(QNetworkRequest::KnownHeaders header) const
  • rawHeader(const QByteArrae& headerName) const
  • rawHeaderList() const
Мрожете через них получить информацию из заголовка ответа.





Спасибо большое) за помощь)

  • #
  • 25 июля 2018 г. 11:40

очень интересно....с компьютера она получает ответ от сервера. Но когда пытаюсь отправить запрос с мобильного телефона то приходит пустот.... не подскажите в чем ошибка? может это из-за того что для Androida в Qt есть какой то другой способ приняться заголовок?

#include "enter_system.h"
#include <QObject>
#include <QNetworkAccessManager>
#include <QNetworkRequest>
#include <QNetworkReply>
#include <QFile>
#include <QUrl>
#include <QDebug>
#include <QHttpPart>
#include <QByteArray>

Enter_system::Enter_system(QObject *parent): QObject(parent)
{

}

void Enter_system::getData(QString myMail, QString myPassword)
{
    qDebug()<<"Прошел"<<endl;
    QString l1 = "j_username=" + myMail;
    QString p1 = "j_password=" + myPassword;
    result = l1 + "&" + p1;
    QByteArray array;
    array.append(result);
    apiUrl =  "https:*******************";
    requestString = array;

    QNetworkRequest request(apiUrl);
    request.setHeader(QNetworkRequest::ContentTypeHeader,QVariant("application/x-www-form-urlencoded"));

    reply = manager.post(request, requestString);

    connect(reply, SIGNAL(finished()),this, SLOT(getReplyFinished()));
    connect(reply, SIGNAL(finished()), this, SLOT(readyReadReply()));
}

void Enter_system::getReplyFinished(){
    reply->deleteLater();
}

void Enter_system::readyReadReply(){
    QString answer = QString::fromUtf8(reply->readAll());
    QList<QByteArray> headerList = reply->rawHeaderList();
    QByteArray head;
    foreach(head, headerList) {
        qDebug() << head << ":-" << reply->rawHeader(head);
    }
    qDebug() <<"headerList = " <<head << ":-" << reply->rawHeader(head);
    QString zapros = reply->rawHeader(head);

    if(zapros == "http://***********/login"){
        myOpen = "Данный пользователь онлайн";
        sendToOpen(myOpen);
        qDebug()<<"Данный пользователь онлайн";
    }else{
        if(zapros == "http://*************")
        {
            myOpen = "true";
            sendToOpen(myOpen);
            qDebug()<<"Авторизация прошла успешно";
        }
        else{
            myOpen = "Отсутствует подключение к сети";
            sendToOpen(myOpen);
            qDebug()<<"Отсутствует подключение к сети"<< zapros;
        }
    }

    //qDebug()<<"headerList = "<<head<<endl;
    qDebug()<<"Прошел1"<<endl;
}

void Enter_system::setSomePropertyMail(const QString &i)                                      //Для обменна даными с переменной way
{
    myMail = i;
    emit sendToMail(myMail);
}

QString Enter_system::getSomePropertyMail()const                                              //Для обменна даными с переменной way
{
    return myMail;
}

void Enter_system::setSomePropertyPassword (const QString &i)                                 //Для обменна даными с переменной time
{
    myPassword = i;
    emit sendToPassword(myPassword);
}

QString Enter_system::getSomePropertyPassword()const                                          //Для обменна даными с переменной time
{
    return myPassword;
}

void Enter_system::setSomePropertyOpen (const QString &i)                                     //Для обменна даными с переменной time
{
    myOpen = i;
    emit sendToPassword(myOpen);
}

QString Enter_system::getSomePropertyOpen()const                                              //Для обменна даными с переменной time
{
    return myOpen;
}


Честно говоря не совсем знаю, какой там подвох может быть.

На ПК используете OpenSSl библиотеку?

Нет, OpenSSl библиотеку не использую. А ее нужно использовать ?  Я на другом телефоне тоже запустил и там похожая ситуация.

По идее, вам понадобится openSSL, когда будете использовать подключения по https...

Правда, под Андроид я не пробовал запускать эту библиотеку, да и времени пока на жто нет


Спасибо)

Ответы

Только авторизованные пользователи могут отвечать на форуме.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
15 августа 2018 г. 19:02
Lord Inquisitoris

C++ - Тест 003. Условия и циклы

  • Результат 57баллов,
  • Очки рейтинга-2
15 августа 2018 г. 18:58
Lord Inquisitoris

C++ - Тест 005. Структуры и Классы

  • Результат 83баллов,
  • Очки рейтинга4
15 августа 2018 г. 9:29
Леха Завистович

C++ - Тест 001. Первая программа и типы данных

  • Результат 86баллов,
  • Очки рейтинга6
Последние комментарии
10 августа 2018 г. 13:40
Alex

Работа с триггерными функциями в PostgreSQL

Приветствую! Если вы создаете новую таблицу, почему бы просто не сделать вьюху ? Просто от одного названия "триггер" как-то не хочется его использовать, а уж кода сколько писа...
10 августа 2018 г. 11:46
Евгений Легоцкой

Bash скрипт для создания и скачивания дампа базы данных и медиа файлов с удаленного сервера

Вон оно что. Не сталкивался с таким, надо будет глянуть исходники дефолтного менеджера объектов. Возможно там кеширование просто. Пробовали добавить запись через adminer, перезапусти...
10 августа 2018 г. 11:34
Alex

Bash скрипт для создания и скачивания дампа базы данных и медиа файлов с удаленного сервера

допустим у нас есть любая таблица, созданная джангой. через админку добавляем пару записей. все ок. далее, лично в моем случае , я открываю adminer, и в эту таблицу добавляю еще одну зап...
Сейчас обсуждают на форуме
15 августа 2018 г. 14:06
Олег Корнев

Как подключить QtCharts в QML?

После некоторых манипуляций (переустановил креатор) смог запустить экземплы с использованием QtCharts, но все они работают с подключениями в файлах .pro .cpp, у меня таких файлов нет. Как...
14 августа 2018 г. 7:02
Ruslan-maniak

Переключение страниц и перевод фокуса на потомка новой страницы

Большое спасибо. Подтолкнули меня на мысль вынести обработку клавиш из PathView на всю страницу. И тогда - да, ваша подсказка работает. добавил в StackView onCurrentItemChanged: currentItem.fo...
14 августа 2018 г. 6:39
Евгений Легоцкой

Как сделать аудиовизуализацию для плеера на qt?

Добрый день. Просмотрите пример в Qt Creator, который на QML, там реализовано визуализация, возможно вам понравится использовать, QML, да и кастомные интерфейсы на нём всё-таки лучше...
11 августа 2018 г. 10:12
Евгений Легоцкой

Qt C++ vs QML

Добрый день. Если Андроид предполагается, то конечно нужно использовать QML. Я занимался разработкой арканоида на QML и ещё одной игры. Пытался реализовывать логику на QML, но это ...
11 августа 2018 г. 9:24
Евгений Легоцкой

Помогите со слоями

Проверочное сообщение

Рекомендуемые страницы