Qt上传文件小记

2024-08-29 18:44
文章标签 qt 上传 小记

本文主要是介绍Qt上传文件小记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近由于公司上线了云平台,需要用Qt与云平台进行对接,故拾起了network模块。

众所周知Qt网络http相关的类QNetworkAccessManager发挥着举足轻重的作用。

普通的http:GET POST PUT DELETE已经耳熟能详,网上也有很多的文章有介绍到。


今天我要说的是平时不常用的上传文件,使用的是QHttpMultiPart模块:

    QUrl url("http://xxx.xxxxxx.com/api/xxxxxx/xxxx/report");QHttpMultiPart* multiPart = new QHttpMultiPart(QHttpMultiPart::FormDataType);//form-data普通字符QString a                 = "TextA";QHttpPart aPart;aPart.setHeader(QNetworkRequest::ContentDispositionHeader, QVariant("form-data; name=\"a\""));aPart.setBody(a.toUtf8());//form-data文件QFile* file = new QFile("D:/xx.db");QString fileName = QFileInfo(*file).fileName();QString fileNaem_ = file->fileName();QHttpPart filePart;//warning 1filePart.setHeader(QNetworkRequest::ContentDispositionHeader, QVariant("form-data; name=\"file\"; filename=\""+fileName+"\""));//warning 2filePart.setHeader(QNetworkRequest::ContentTypeHeader, "application/octet-stream");if(file->open(QIODevice::ReadOnly)) {filePart.setBodyDevice(file);}file->setParent(multiPart);//form-data文件2QString fileName1 = QFileInfo(*file1).fileName();QString fileName1_ = file1->fileName();QHttpPart filePart1;//warning 1filePart1.setHeader(QNetworkRequest::ContentDispositionHeader, QVariant("form-data; name=\"data\"; filename=\""+fileName1+"\""));//warning 2filePart1.setHeader(QNetworkRequest::ContentTypeHeader, "application/json");if(file1->open(QIODevice::ReadOnly)) {filePart1.setBodyDevice(file1);}file1->setParent(multiPart);multiPart->append(aPart);multiPart->append(filePart);multiPart->append(filePart1);QNetworkRequest request(url);QString bdry = multiPart->boundary();//warning 3request.setHeader(QNetworkRequest::ContentTypeHeader,"multipart/form-data;boundary=" + bdry);QNetworkReply *reply = manager->post(request, multiPart);connect(reply, &QNetworkReply::uploadProgress, [=](qint64 bytesSent, qint64 bytesTotal){if ((reply->error() == QNetworkReply::NoError) &&(0 != bytesSent) && (0 != bytesTotal)){int uploadProgress = static_cast<int>(bytesSent * 100 / bytesTotal);qDebug() << "###-->" << uploadProgress << endl;}});

代码中的warning1、warning2、warning3这三个地方需要注意,基本没什么问题。

如果有问题的话,可以先用postman测试,测试OK的话,同步使用Fiddler进行抓包查看一下具体发送的数据是什么:


Postman截图:


 

Fiddler截图: 


然后再使用Qt发送命令,对比一下两者发送http请求数据的区别,这样可以快速找到问题所在,及时调整代码并测试。

这篇关于Qt上传文件小记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1118648

相关文章

Qt 中 isHidden 和 isVisible 的区别与使用小结

《Qt中isHidden和isVisible的区别与使用小结》Qt中的isHidden()和isVisible()方法都用于查询组件显示或隐藏状态,然而,它们有很大的区别,了解它们对于正确操... 目录1. 基础概念2. 区别清见3. 实际案例4. 注意事项5. 总结1. 基础概念Qt 中的 isHidd

Java实现数据库图片上传与存储功能

《Java实现数据库图片上传与存储功能》在现代的Web开发中,上传图片并将其存储在数据库中是常见的需求之一,本文将介绍如何通过Java实现图片上传,存储到数据库的完整过程,希望对大家有所帮助... 目录1. 项目结构2. 数据库表设计3. 实现图片上传功能3.1 文件上传控制器3.2 图片上传服务4. 实现

QT移植到RK3568开发板的方法步骤

《QT移植到RK3568开发板的方法步骤》本文主要介绍了QT移植到RK3568开发板的方法步骤,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录前言一、获取SDK1. 安装依赖2. 获取SDK资源包3. SDK工程目录介绍4. 获取补丁包二

Qt把文件夹从A移动到B的实现示例

《Qt把文件夹从A移动到B的实现示例》本文主要介绍了Qt把文件夹从A移动到B的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录如何移动一个文件? 如何移动文件夹(包含里面的全部内容):如何删除文件夹:QT 文件复制,移动(

使用mvn deploy命令上传jar包的实现

《使用mvndeploy命令上传jar包的实现》本文介绍了使用mvndeploy:deploy-file命令将本地仓库中的JAR包重新发布到Maven私服,文中通过示例代码介绍的非常详细,对大家的学... 目录一、背景二、环境三、配置nexus上传账号四、执行deploy命令上传包1. 首先需要把本地仓中要

Java实现数据库图片上传功能详解

《Java实现数据库图片上传功能详解》这篇文章主要为大家详细介绍了如何使用Java实现数据库图片上传功能,包含从数据库拿图片传递前端渲染,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、前言2、数据库搭建&nbsChina编程p; 3、后端实现将图片存储进数据库4、后端实现从数据库取出图片给前端5、前端拿到

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

Vue ElementUI中Upload组件批量上传的实现代码

《VueElementUI中Upload组件批量上传的实现代码》ElementUI中Upload组件批量上传通过获取upload组件的DOM、文件、上传地址和数据,封装uploadFiles方法,使... ElementUI中Upload组件如何批量上传首先就是upload组件 <el-upl

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

基于Qt Qml实现时间轴组件

《基于QtQml实现时间轴组件》时间轴组件是现代用户界面中常见的元素,用于按时间顺序展示事件,本文主要为大家详细介绍了如何使用Qml实现一个简单的时间轴组件,需要的可以参考下... 目录写在前面效果图组件概述实现细节1. 组件结构2. 属性定义3. 数据模型4. 事件项的添加和排序5. 事件项的渲染如何使用