qt QNetworkAccessManager详解

1、概述

QNetworkAccessManager是QtNetwork模块中的一个核心类,它允许应用程序发送网络请求并接收响应。该类是网络通信的基石,提供了一种方便的方式来处理常见的网络协议,如HTTP、HTTPS等。QNetworkAccessManager对象持有其发送的请求的通用配置和设置,包括代理、缓存配置等,并且包含了与此类问题相关的信号,以及可用于监视网络操作进展的回复信号。

2、重要方法

QNetworkAccessManager类提供了多种方法来发送网络请求,其中最常用的包括:

  • get():发送一个GET请求到指定的URL。
  • post():发送一个POST请求到指定的URL,并附带请求数据。
  • put()upload()等:用于执行更复杂的网络操作,如文件上传等。

此外,QNetworkAccessManager还提供了一些其他方法,如设置代理、处理重定向、处理身份验证等,以满足不同的网络需求。

3、重要信号

QNetworkAccessManager类定义了多个信号,用于通知应用程序网络操作的进展和结果。其中一些重要的信号包括:

  • finished(QNetworkReply*):当网络请求完成时触发此信号。QNetworkReply对象包含了下载的数据以及元数据(如头部信息)。
  • readyRead():当QNetworkReply对象中有新的数据可读时触发此信号。这允许应用程序在数据到达时逐步读取,而不是等待整个响应完成。
  • error(QNetworkReply::NetworkError):当网络请求出现错误时触发此信号。QNetworkReply::NetworkError枚举类型指定了错误的类型。

此外,QNetworkReply对象还定义了其他信号,如sslErrors()、uploadProgress()、downloadProgress()等,用于提供关于SSL错误、上传进度和下载进度的信息。

4、常用枚举类型

QNetworkAccessManager和QNetworkReply类定义了一些枚举类型,用于表示网络操作的状态和结果。以下是一些常用的枚举类型:

  • QNetworkAccessManager::NetworkAccessibility:表示网络是否可以通过该网络访问管理器访问。它用于检测应用程序的网络访问状态。
  • QNetworkAccessManager::Operation:表示QNetworkReply对象正在处理的操作类型,如GET、POST等。
  • QNetworkReply::NetworkError:表示在处理网络请求过程中可能出现的错误类型。

这些枚举类型提供了丰富的信息,帮助应用程序更好地处理网络请求和响应。

//模拟服务端

from flask import Flask, request, jsonifyapp = Flask(__name__)# 模拟一个数据库,用字典存储数据
data_store = {}# GET 请求: 获取数据
@app.route('/data/<int:item_id>', methods=['GET'])
def get_data(item_id):item = data_store.get(item_id)if item:return jsonify(item), 200return jsonify({"message": "Item not found"}), 404# POST 请求: 创建数据
@app.route('/data', methods=['POST'])
def create_data():# 从请求体中获取 JSON 数据new_item = request.get_json()item_id = new_item.get('id')if not item_id:return jsonify({"message": "ID is required"}), 400# 如果 ID 已存在,返回错误if item_id in data_store:return jsonify({"message": "Item with this ID already exists"}), 400# 保存数据到“数据库”data_store[item_id] = new_itemreturn jsonify(new_item), 201# PUT 请求: 修改数据
@app.route('/data/<int:item_id>', methods=['PUT'])
def update_data(item_id):# 从请求体中获取 JSON 数据updated_item = request.get_json()if item_id not in data_store:return jsonify({"message": "Item not found"}), 404# 更新数据data_store[item_id] = updated_itemreturn jsonify(updated_item), 200# DELETE 请求: 删除数据
@app.route('/data/<int:item_id>', methods=['DELETE'])
def delete_data(item_id):if item_id in data_store:del data_store[item_id]return jsonify({"message": "Item deleted"}), 200return jsonify({"message": "Item not found"}), 404if __name__ == '__main__':app.run(debug=True)

客户端:

#include <QApplication>
#include <QWidget>
#include <QVBoxLayout>
#include <QPushButton>
#include <QTextEdit>
#include <QLineEdit>
#include <QLabel>
#include <QNetworkAccessManager>
#include <QNetworkRequest>
#include <QNetworkReply>
#include <QJsonDocument>
#include <QJsonObject>class HttpClient : public QWidget {Q_OBJECTpublic:HttpClient(QWidget *parent = nullptr) : QWidget(parent) {initUI();manager = new QNetworkAccessManager(this);}private slots:void getData() {QString itemId = idInput->text();QNetworkRequest request(QUrl("http://127.0.0.1:5000/data/" + itemId));request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json");QNetworkReply *reply = manager->get(request);connect(reply, &QNetworkReply::finished, this, [=]() {responseLabel->setText("Response: " + reply->readAll());reply->deleteLater();});}void createData() {QString itemData = dataInput->toPlainText();QNetworkRequest request(QUrl("http://127.0.0.1:5000/data"));request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json");QNetworkReply *reply = manager->post(request, itemData.toUtf8());connect(reply, &QNetworkReply::finished, this, [=]() {responseLabel->setText("Response: " + reply->readAll());reply->deleteLater();});}void updateData() {QString itemId = idInput->text();QString itemData = dataInput->toPlainText();QNetworkRequest request(QUrl("http://127.0.0.1:5000/data/" + itemId));request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json");QNetworkReply *reply = manager->put(request, itemData.toUtf8());connect(reply, &QNetworkReply::finished, this, [=]() {responseLabel->setText("Response: " + reply->readAll());reply->deleteLater();});}void deleteData() {QString itemId = idInput->text();QNetworkRequest request(QUrl("http://127.0.0.1:5000/data/" + itemId));request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json");QNetworkReply *reply = manager->deleteResource(request);connect(reply, &QNetworkReply::finished, this, [=]() {responseLabel->setText("Response: " + reply->readAll());reply->deleteLater();});}private:void initUI() {setWindowTitle("HTTP Client");QVBoxLayout *layout = new QVBoxLayout(this);idInput = new QLineEdit(this);idInput->setPlaceholderText("Enter Item ID");layout->addWidget(idInput);dataInput = new QTextEdit(this);dataInput->setPlaceholderText("Enter JSON data (for POST/PUT)");layout->addWidget(dataInput);responseLabel = new QLabel("Response:", this);layout->addWidget(responseLabel);QPushButton *getButton = new QPushButton("GET", this);connect(getButton, &QPushButton::clicked, this, &HttpClient::getData);layout->addWidget(getButton);QPushButton *postButton = new QPushButton("POST", this);connect(postButton, &QPushButton::clicked, this, &HttpClient::createData);layout->addWidget(postButton);QPushButton *putButton = new QPushButton("PUT", this);connect(putButton, &QPushButton::clicked, this, &HttpClient::updateData);layout->addWidget(putButton);QPushButton *deleteButton = new QPushButton("DELETE", this);connect(deleteButton, &QPushButton::clicked, this, &HttpClient::deleteData);layout->addWidget(deleteButton);setLayout(layout);}QLineEdit *idInput;QTextEdit *dataInput;QLabel *responseLabel;QNetworkAccessManager *manager;
};int main(int argc, char *argv[]) {QApplication app(argc, argv);HttpClient client;client.show();return app.exec();
}

觉得有帮助的话,打赏一下呗。。

           

需要商务合作(定制程序)的欢迎私信!! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/888781.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

21、结构体成员分布

结构体中的成员并不是紧挨着分布的&#xff0c;内存分布遵循字节对齐的原则。 按照成员定义的顺序&#xff0c;遵循字节对齐的原则存储。 字节对齐的原则&#xff1a; 找成员中占据字节数最大的成员&#xff0c;以它为单位进行空间空配 --- 遇到数组看元素的类型 每一个成员距离…

前端基础——CSS

美化文档 HTML内部添加样式 本节我们来学习如何在标签中引入CSS样式。 1 在标签中添加声明 声明的关键字是style后接等号&#xff08;&#xff09;再接引号&#xff08;""&#xff09;&#xff0c;即style"" 具体声明如下&#xff1a; <input typ…

WPS解决Word文件引入excel对象文件无法打开提示“不能启动此对象...”的问题

一、问题现象 接收到了一份 Word文件&#xff0c;里面引入了一个Excel对象文件&#xff0c;双击时候&#xff0c;wps出现卡顿&#xff0c;过一会之后弹出错误提示&#xff1a;不能启动此对象... 二、解决方法 1.点击WPS左上角图标&#xff0c;并打开右上角设置&#xff0c;萱蕚…

在 Linux 系统中,可以使用以下简单快捷的方法来模拟 CPU 负载

在 Linux 系统中&#xff0c;可以使用以下简单快捷的方法来模拟 CPU 负载&#xff1a; 1. 使用 stress 工具 stress 是一个专门用于压力测试的工具&#xff0c;可以模拟 CPU、内存、I/O 等负载。 安装 stress&#xff1a; # Debian/Ubuntu 系统 sudo apt-get install stres…

spring下的beanutils.copyProperties实现深拷贝

spring下的beanutils.copyProperties方法是深拷贝还是浅拷贝&#xff1f;可以实现深拷贝吗&#xff1f; 答案&#xff1a;浅拷贝。 一、浅拷贝深拷贝的理解 简单说拷贝就是将一个类中的属性拷贝到另一个中&#xff0c;对于BeanUtils.copyProperties来说&#xff0c;你必须保…

【SpringBoot项目拆分】

背景&#xff1a;两个项目都使用相同了的底层方法&#xff0c;每次变更都需要修改两个项目&#xff0c;所以就考虑是否可以抽出来一个单独的项目来维护这些底层方法。 在网上找了很多发现都是新建module的&#xff0c;这种方法适合一个项目内部优化结构&#xff0c;不适合两个…

3GPP R18 LTM(L1/L2 Triggered Mobility)是什么鬼?(三) RACH-less LTM cell switch

这篇看下RACH-less LTM cell switch。 相比于RACH-based LTM,RACH-less LTM在进行LTM cell switch之前就要先知道target cell的TA信息,进而才能进行RACH-less过程,这里一般可以通过UE自行测量或者通过RA过程获取,而这里的RA一般是通过PDCCH order过程触发。根据38.300中的描…

Ansible 运维工具

安装 apt install ansible /etc/ansible/hosts , 指定密码或密钥访问分组机器 [k8s_masters] master0.c0.k8s.sb[k8s_nodes] node0.c0.k8s.sb node1.c0.k8s.sb[k8s:children] k8s_masters k8s_nodes[k8s_masters:vars] ansible_ssh_usersbadmin ansible_ssh_pass"***&q…

C++的Find算法用法,

在 C 中&#xff0c;可以使用 std::map 统计值出现次数为 2 的键。具体步骤如下&#xff1a; 遍历 std::map&#xff0c;找出所有值为 2 的键。使用条件语句检查每个值&#xff0c;符合条件时记录对应键。 #include <iostream> #include <map> #include <vect…

《鸟哥的Linux私房菜基础篇》---4 Linux档案的压缩与打包

目录 一、常见的压缩包的扩展名 二、常见的压缩和解压指令 1、tar 2、tar gzip&#xff08;.tar.gz&#xff09; (或 .tgz) 3、tar bzip2&#xff08;.tar.bz2&#xff09; 4、zip 5、gzip 6、bzip2 7、xz 8、rar 9、7z 三、安装解压工具 一、常见的压缩包的扩展…

基于springboot的音乐网站的设计与实现

文末获取源码和万字论文&#xff0c;制作不易&#xff0c;感谢点赞支持。 音乐网站 摘要 随着信息技术在管理上越来越深入而广泛的应用&#xff0c;管理信息系统的实施在技术上已逐步成熟。本文介绍了音乐网站的开发全过程。通过分析音乐网站管理的不足&#xff0c;创建了一个计…

【软考速通笔记】系统架构设计师⑲——专业英语

文章目录 一、前言二、常用名词三、架构风格四、非功能需求五、应用架构六、软件架构重用 一、前言 笔记目录大纲请查阅&#xff1a;【软考速通笔记】系统架构设计师——导读 二、常用名词 名词翻译architecture架构system系统design设计requirements需求components组件constr…

三菱JET伺服CC-Link IE现场网络Basic链接软元件(RYn/RXn)(RWwn/RWrn)

链接软元件(RYn/RXn) 要点 在循环通信中对主站发送给伺服放大器的请求(RYn及RWwn)设定了范围外的值时&#xff0c;将无法反映设定内容。 循环通信的请求报文与响应报文的收发数据被换读为伺服放大器的对象数据(RYn、RXn)。 响应报文的设定值可进行变更。变更初始设定值时&…

WPF中的VisualState(视觉状态)

以前在设置控件样式或自定义控件时&#xff0c;都是使用触发器来进行样式更改。触发器可以在属性值发生更改时启动操作。 像这样&#xff1a; <Style TargetType"ListBoxItem"><Setter Property"Opacity" Value"0.5" /><Setter …

ARINC 标准全解析:航空电子领域多系列标准的核心内容、应用与重要意义

ARINC标准概述 ARINC标准是航空电子领域一系列重要的标准规范&#xff0c;由航空电子工程委员会&#xff08;AEEC&#xff09;编制&#xff0c;众多航空公司等参与支持。这些标准涵盖了从飞机设备安装、数据传输到航空电子设备功能等众多方面&#xff0c;确保航空电子系统的兼…

用golang简单做一个内网穿透小工具!

一个个人需求&#xff0c;需要简单的穿透一下 家里的电脑&#xff0c;也不需要多稳定&#xff0c;也没有并发。然后 通过http可以访问到内网的 一个网站&#xff0c; 因为服务端 是linux 系统 &#xff0c;内网是 windows10服务器 所以 就采用 用golang这个语言来实现&#xff…

Android Studio 历史版本下载

Android Studio 历史版本下载 官方链接&#xff1a;https://developer.android.google.cn/studio/archive 通过gradle插件版本反查Android Studio历史版本 Android Studio Ladybug | 2024.2.1 October 1, 2024 【https://redirector.gvt1.com/edgedl/android/studio/ide-zip…

微服务监控prometheus+Grafana

目录 Prometheus 概述 核心组件 特点 使用场景 Grafana 概述 功能特点 使用场景 PrometheusGrafana组合 部署和配置 一、准备工作 二、部署Prometheus 三、部署Grafana 四、创建监控仪表盘 五、验证和调优 总结 微服务监控是确保微服务架构稳定运行的关键环节…

(vue)el-cascader多选级联选择器,值取最后一级的数据

(vue)el-cascader多选级联选择器&#xff0c;取值取最后一级的数据 获取到&#xff1a;[“养殖区”,“鸡棚”,“E5001”] 期望&#xff1a;[“E5001”] 问题: 解决方法 增加change事件方法&#xff0c;处理选中的value值 1.单选 <el-cascaderv-model"tags2":o…