当前位置:   article > 正文

QT中网络编程之发送Http协议的Get和Post请求_qt http请求

qt http请求


使用QT的开发产品最终作为一个客户端来使用,很大的一个功能就是要和后端服务器进行交互。
当前使用的QT版本如下:
在这里插入图片描述

HTTP协议

超文本传输协议(Hyper Text Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。请求和响应消息的头以ASCII形式给出;而 消息内容则具有一个类似MIME的格式。
在这里插入图片描述

GET请求

GET 从指定的资源请求数据。必要时,可以将查询字符串参数追加到URL的末尾,以便将信息发送给服务器。GET因为参数会放在url中,所以隐私性,安全性较差,请求的数据长度是有限制的,不同的浏览器和服务器不同,一般限制在 2~8K 之间,更加常见的是 1k 以内。

POST请求

POST向指定的资源提交要被处理的数据。POST请求应该把数据作为请求的主体提交,请求主体(body)可以包括非常多的数据,且数据格式不限。POST请求是没有的长度限制,请求数据是放在body中。

QT中对HTTP协议的处理

Qt中提供了QNetworkAccessManager、QNetworkRequest和QNetworkReply,用于应用程序对网络访问的处理。

1.QNetworkAccessManager

QNetworkAccessManager 提供了应用程序通过网络发送请求的能力。

2.QNetworkRequest

QNetworkRequest 保存通过网络发送请求所需的信息。 它包含一个 URL 和一些可用于修改请求的辅助信息。

3.QNetworkReply

QNetworkReply 类封装了使用 QNetworkAccessManager 发布的请求相关的回复信息。QNetworkReply 是 QIODevice的子类,这意味着一旦从对象中读取数据,它就不再由设备保留。因此,如果需要,应用程序有责任保留这些数据。

QT实现GET请求和POST请求

项目结构预览:
在这里插入图片描述
在这里插入图片描述
头文件httpoperate.h内容

#ifndef HTTPOPERATE_H
#define HTTPOPERATE_H

#include <QtNetwork/QNetworkAccessManager>
#include <QtNetwork/QNetworkReply>

class HttpOperate:public QObject
{
    Q_OBJECT
public:
    HttpOperate();
    void SendPostRequst();//用于发送Post请求的成员函数
    void SendGetRequst();//用于发生Get请求的成员函数

private:
    QNetworkAccessManager* mNetworkManager;
    QNetworkReply* mReply;

public slots: //类中做槽函数的成员函数一般写在public slots下,Qt5以及以上版本可以不写public slots
    void ReplyFinshed();
};

#endif // HTTPOPERATE_H
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

源文件httpoperate.cpp中的内容

#include "httpoperate.h"
#include <QJsonDocument>
#include <QJsonObject>
#include <QStringDecoder>
#include <QObject>
HttpOperate::HttpOperate() {}

void HttpOperate::SendGetRequst()
{
    mNetworkManager = new QNetworkAccessManager(this);
    QNetworkRequest _quest;
    QString url = "http://127.0.0.1:8083/v3/api/client/v1/captchaImage";
    url.append("?key1=小强&key2=xiao qing");
    _quest.setUrl((QUrl(url)));
    _quest.setHeader(QNetworkRequest::ContentTypeHeader,"application/x-www-form-urlencoded");
    mReply = mNetworkManager->get(_quest);
    QByteArray _data = mReply->readAll();//读出数据
    //QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss.zzz").toUtf8().constData();
    qInfo()<<"1_data ==> "<<_data;
    //connect(mReply,&QNetworkReply::finished,this,&HttpOperate::ReplyFinshed);//方式一
    // auto lambdaFun = [=]{ReplyFinshed();};//lambda函数
    // connect(mReply,&QNetworkReply::finished,lambdaFun);//这里的信号的接受者可以省略不写
    connect(mReply,&QNetworkReply::finished,[=]{//这里的信号的接受者可以省略不写
        ReplyFinshed();
    });
    qInfo()<<"2_data ==> " << QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss.zzz").toUtf8().constData();
}

void HttpOperate::SendPostRequst()
{
    mNetworkManager = new QNetworkAccessManager(this);
    QNetworkRequest _quest;
    _quest.setUrl((QUrl("http://127.0.0.1:8083/v3/api/client/v1/createSignature")));
    // _quest.setHeader(QNetworkRequest::ContentTypeHeader,"application/x-www-form-urlencoded");
    _quest.setHeader(QNetworkRequest::ContentTypeHeader,"application/json");
    QJsonDocument document;
    QJsonObject obj;
    obj.insert("key1", "小明");
    obj.insert("key2", "xiao hong");
    document.setObject(obj);
    QByteArray _postData = document.toJson(QJsonDocument::Compact);//以Json字符串的方式传参
    mReply = mNetworkManager->post(_quest,_postData);
    QByteArray _data = mReply->readAll();//读出数据
    qDebug()<<"1_data ==> "<<_data;//此s时数据为空
    //connect(mReply,&QNetworkReply::finished,this,&HttpOperate::ReplyFinshed);//方式一
    // auto lambdaFun = [=]{ReplyFinshed();};//lambda函数
    // connect(mReply,&QNetworkReply::finished,this,lambdaFun);//方式二
    connect(mReply,&QNetworkReply::finished,this,[=]{
        ReplyFinshed();
    });//方式三
    qDebug()<<"2_data ==> ";
}

void HttpOperate::ReplyFinshed()
{
    if (mReply->error() == QNetworkReply::NoError)
    {
        // 处理返回的数据
        QByteArray _data = mReply->readAll();//读出数据
        auto toUtf16 = QStringDecoder(QStringDecoder::Utf8);
        QString str = toUtf16(_data);
        qInfo()<<"_data ==> "<<str;
    } else {
        // 处理错误
        qDebug()<<"error ==> "<<mReply->error();
    }
    mReply->deleteLater();
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68

main.cpp中的代码:

#include <QCoreApplication>
#include "httpoperate.h"
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    HttpOperate hoper;
    hoper.SendPostRequst();//发起Post请求测试

    HttpOperate hoper1;
    hoper1.SendGetRequst();//发起Get请求测试
    return a.exec();//主程序会在这里阻塞
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

注意:当槽函数是 全局函数,或者 lambda式函数时,信号的接收者可以省略不写。

Get请求步骤

步骤:
1. 初始化QNetworkAccessManager对象。
2. 设置请求URL。
3. 连接消息返回。
4. 发送GET请求。
上面的关键代码就是:

/*内部发起http连接,连接成功后发起get请求.
  此接口是异步接口。请求发起后,会立即返回一个QNetworkReply类型对象的地址,
  此时打印它如上的1_data ==>结果为空字符串。
  当get请求响应返回后,会自动触发mReply所指对象的finished信号,此时mReply指对象里就有数据了,类似于Ajax的请求方式。
  然后调用响应的槽函数ReplyFinshed()处理读取数据的操作。
*/
mReply = mNetworkManager->post(_quest,_postData);
connect(mReply,&QNetworkReply::finished,this,&HttpOperate::ReplyFinshed);//将信号和槽函数进行关联,类似于绑定或注册的作用
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

Post请求步骤

初始化QNetworkAccessManager对象。
设置请求URL。
设置请求头Header
设置请求主体
连接消息返回。
发送POST请求。

/*内部发起http连接,连接成功后发起post请求.
  此接口是异步接口。请求发起后,会立即返回一个QNetworkReply类型对象的地址,
  此时打印它如上的1_data ==>结果为空字符串。
  当get请求响应返回后,会自动触发mReply所指对象的finished信号,此时mReply指对象里就有数据了,类似于Ajax的请求方式。
  然后调用响应的槽函数ReplyFinshed()处理读取数据的操作。
*/
mReply = mNetworkManager->get(_quest);
connect(mReply,&QNetworkReply::finished,this,&HttpOperate::ReplyFinshed);//将信号和槽函数进行关联,类似于绑定或注册的作用
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

测试结果

get请求测试后端服务使用的是springboot服务
后端接口为:
在这里插入图片描述
后端打印内容:
在这里插入图片描述
QT控制台输出内容:
在这里插入图片描述
post请求测试后端服务使用的也是springboot服务
后端接口为:
在这里插入图片描述
后端打印内容:
在这里插入图片描述
QT控制台输出内容:
在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/740558
推荐阅读
相关标签
  

闽ICP备14008679号