news 2026/6/14 22:31:43

Qt/C++ 实现文件双向传输:从客户端到服务端,再从服务端到客户端

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Qt/C++ 实现文件双向传输:从客户端到服务端,再从服务端到客户端

Qt/cpp实现的客户端往服务端传输文件、服务端往客户端传输文件,可监测传输状态,可控制传输。 源码: 使用Qt5.6.1_MinGW编译通过。 c.37

在很多网络应用场景中,文件的双向传输,也就是客户端往服务端传输文件以及服务端往客户端传输文件,并且能够监测传输状态和对传输进行控制,是非常常见的需求。今天就来聊聊如何使用 Qt/C++ 来实现这一功能。

一、环境说明

本文的代码使用 Qt5.6.1_MinGW 编译通过,确保你也配置好了相应的开发环境,以便顺利运行和理解代码。

二、客户端往服务端传输文件

1. 建立连接

首先,我们需要在客户端和服务端之间建立一个 TCP 连接。在 Qt 中,可以使用 QTcpSocket 来实现。

QTcpSocket *socket = new QTcpSocket(this); socket->connectToHost(QHostAddress::LocalHost, 1234); if(socket->waitForConnected(5000)) { qDebug() << "Connected to server!"; } else { qDebug() << "Could not connect: " << socket->errorString(); }

这里我们创建了一个 QTcpSocket 对象,并尝试连接到本地主机的 1234 端口。waitForConnected函数会阻塞等待,直到连接建立或者超时,这里设置的超时时间是 5 秒。如果连接成功,会输出连接成功的信息,否则输出错误信息。

2. 文件传输

接下来进行文件传输。假设我们要传输的文件是test.txt

QFile file("test.txt"); if(!file.open(QIODevice::ReadOnly)) { qDebug() << "Could not open file"; return; } qint64 totalBytes = file.size(); qint64 bytesWritten = 0; qint64 bytesToWrite = totalBytes; while(bytesToWrite > 0) { QByteArray buffer = file.read(qMin(bytesToWrite, (qint64)1024)); qint64 written = socket->write(buffer); if(written == -1) { qDebug() << "Write error: " << socket->errorString(); break; } bytesWritten += written; bytesToWrite -= written; qDebug() << "Transferred " << bytesWritten << " of " << totalBytes << " bytes"; } file.close(); socket->close();

首先打开要传输的文件,如果打开失败则输出错误信息并返回。获取文件的总大小totalBytes,然后循环读取文件内容并写入到 socket 中。每次读取最多 1024 字节的数据,写入成功后更新已传输字节数bytesWritten和剩余要传输字节数bytesToWrite,并输出当前传输进度。传输完成后关闭文件和 socket。

3. 监测传输状态

为了监测传输状态,我们可以在传输过程中实时输出已传输字节数和总字节数,就像上面代码中那样。也可以使用信号槽机制,比如QTcpSocketbytesWritten信号。

connect(socket, SIGNAL(bytesWritten(qint64)), this, SLOT(updateTransferProgress(qint64))); void MyClass::updateTransferProgress(qint64 bytes) { static qint64 totalBytes = 0; totalBytes += bytes; qDebug() << "Transferred " << totalBytes << " bytes so far"; }

这里将bytesWritten信号连接到自定义的槽函数updateTransferProgress,在槽函数中累加已传输字节数并输出。

4. 控制传输

可以通过一些逻辑来控制传输,比如暂停和继续。我们可以在连接成功后设置一个标志位来表示传输状态。

bool isPaused = false; // 假设这里有一个暂停按钮的点击事件槽函数 void MyClass::onPauseButtonClicked() { isPaused = true; socket->pause(); } // 继续按钮的点击事件槽函数 void MyClass::onResumeButtonClicked() { isPaused = false; socket->resume(); }

当点击暂停按钮时,设置isPaused为 true 并调用socket->pause()暂停传输;点击继续按钮时,设置isPaused为 false 并调用socket->resume()继续传输。

三、服务端往客户端传输文件

1. 监听连接

服务端需要监听客户端的连接请求,使用 QTcpServer 来实现。

QTcpServer *server = new QTcpServer(this); if(!server->listen(QHostAddress::LocalHost, 1234)) { qDebug() << "Could not start server: " << server->errorString(); return; } connect(server, SIGNAL(newConnection()), this, SLOT(handleNewConnection()));

创建一个 QTcpServer 对象并尝试监听本地主机的 1234 端口。如果监听失败,输出错误信息并返回。将newConnection信号连接到自定义的槽函数handleNewConnection,当有新的客户端连接时会调用这个槽函数。

2. 文件传输

handleNewConnection槽函数中进行文件传输。假设要传输的文件也是test.txt

void MyClass::handleNewConnection() { QTcpSocket *socket = server->nextPendingConnection(); QFile file("test.txt"); if(!file.open(QIODevice::ReadOnly)) { qDebug() << "Could not open file"; socket->close(); return; } qint64 totalBytes = file.size(); qint64 bytesWritten = 0; qint64 bytesToWrite = totalBytes; while(bytesToWrite > 0) { QByteArray buffer = file.read(qMin(bytesToWrite, (qint64)1024)); qint64 written = socket->write(buffer); if(written == -1) { qDebug() << "Write error: " << socket->errorString(); break; } bytesWritten += written; bytesToWrite -= written; qDebug() << "Transferred " << bytesWritten << " of " << totalBytes << " bytes"; } file.close(); socket->close(); }

这里获取新连接的 socket,打开要传输的文件,然后和客户端往服务端传输文件类似,循环读取文件内容并写入到 socket 中,实时输出传输进度。传输完成后关闭文件和 socket。

3. 监测传输状态与控制传输

和客户端类似,服务端也可以通过信号槽机制监测传输状态,比如使用bytesWritten信号。控制传输的逻辑也可以类似实现,设置标志位并通过相应的函数来暂停和继续传输。

通过以上步骤,我们就实现了 Qt/C++ 客户端往服务端传输文件、服务端往客户端传输文件,并且能够监测传输状态和控制传输的功能。希望这篇文章对你在网络文件传输相关的开发中有帮助。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 11:18:16

AI安全合规评估服务系统:给智能时代加把“技术安全锁”

如今AI技术已经渗透到金融、医疗、政务等各个领域&#xff0c;但随之而来的算法偏见、数据泄露、合规风险也越来越突出。AI安全合规评估服务系统&#xff0c;本质上就是一套“AI专属安检设备”&#xff0c;用技术手段帮企业排查AI应用的安全漏洞和合规问题&#xff0c;让智能技…

作者头像 李华
网站建设 2026/6/15 12:19:47

雷达原理 魏青 笔记 第二章 雷达发射机原理

雷达发射机原理与任务一、 引言&#xff1a;从概论到发射机在上节课中&#xff0c;我们完成了第一章内容的学习&#xff0c;主要涵盖了雷达概论&#xff0c;包括雷达测距、测角、测速的原理&#xff0c;雷达成像的各个方面&#xff0c;以及基本的雷达方程。我们了解到&#xff…

作者头像 李华
网站建设 2026/6/14 19:40:43

AI如何革新漏洞扫描工具的开发流程

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个基于AI的漏洞扫描工具&#xff0c;能够自动分析代码和网络流量&#xff0c;识别常见漏洞如SQL注入、XSS等。工具应具备以下功能&#xff1a;1. 支持多种编程语言和框架的代…

作者头像 李华
网站建设 2026/6/15 3:49:56

MATLAB 环境下信号的同步压缩广义 Stockwell 变换探索

MATLAB环境下信号的同步压缩广义Stockwell变换 算法测试环境为MATLAB R2018A&#xff0c;通过自适应窗函数压缩信号在S域的时频谱值&#xff0c;提高了算法的灵活性和时频分析聚焦能力。 算法可迁移至金融时间序列&#xff0c;地震信号&#xff0c;语音信号&#xff0c;声信号&…

作者头像 李华
网站建设 2026/6/14 20:12:48

Gradle依赖缓存损坏?新手也能轻松搞定

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个面向初学者的Gradle依赖缓存修复工具&#xff0c;提供一键修复功能。工具应自动检测问题并执行修复&#xff0c;无需用户输入复杂命令。界面简洁明了&#xff0c;提供修复进…

作者头像 李华
网站建设 2026/6/15 13:06:24

小白程序员的进阶之路:Java大厂求职面试实录

小白程序员的进阶之路&#xff1a;Java大厂求职面试实录 第一轮提问&#xff1a;核心技术与微服务基础 面试官&#xff1a; 请你描述一下Java SE 8中的Lambda表达式以及它们如何帮助提高代码的可读性&#xff1f;如何使用Spring Boot快速构建一个微服务应用&#xff1f;你了解过…

作者头像 李华