QTcpSocket客户端和服务端发送图片(或大文件)小Demo
生活随笔
收集整理的這篇文章主要介紹了
QTcpSocket客户端和服务端发送图片(或大文件)小Demo
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
先看一下效果:
思路:
發(fā)圖片、大文件與發(fā)短字符不大一樣。
1、文件和圖片通過TCP可能一次發(fā)不過去,可能要發(fā)很多次。所以我們在發(fā)送文件、數(shù)據(jù)、以及文字最好帶上文件的大小。
2、圖片轉(zhuǎn)換成文件流的形式,這個(gè)Demo是轉(zhuǎn)成base64加密流
核心代碼:
1、tcp客戶端與服務(wù)端的代碼這里就不貼了,以前貼過,可以看我以前的帖子。這里貼一下思路代碼:
發(fā)送圖片端:
QByteArray byte = "P" + QByteArray::number(m_base64.length()) + "P";m_tcpClient->sendMessageB(byte);qDebug() << "len" << byte;m_tcpClient->sendMessageB(m_base64); 這里的“P”只是一個(gè)分隔符,可以自定義。m_base64是圖片轉(zhuǎn)換成的QByteArray。看一下接收圖片端:
QByteArray tmp = m_socket->readAll();if(m_dataLength != 0) {m_byte.append(tmp);m_dataLength = m_dataLength - tmp.length();qDebug() << "m_dataLength " << m_dataLength;if(m_dataLength == 0) {emit alreadyRead();}} else {int len;if(tmp.contains("P")) {m_type = "P";len = tmp.split('P').at(1).toInt();} else if(tmp.contains("T")){m_type = "T";len = tmp.split('T').at(1).toInt();}int preNum = 2 + QString::number(len).count();m_dataLength = len + preNum - tmp.length();m_byte.clear();m_byte = tmp.mid(preNum, tmp.count() - preNum);}2、圖片轉(zhuǎn)換成文字流的代碼:
#ifndef SBASE64TOIMAGE_H #define SBASE64TOIMAGE_H#include <QByteArray> #include <QBuffer> #include <QImage> #include <QPixmap>class SBase64ToImage : public QObject {Q_OBJECT public:static QByteArray Image_To_Base64(QString ImgPath) {QImage image(ImgPath);QByteArray ba;QBuffer buf(&ba);image.save(&buf,"PNG",20);QByteArray hexed = ba.toBase64();buf.close();return hexed;}static QPixmap Base64_To_Image(QByteArray bytearray) {QByteArray Ret_bytearray = QByteArray::fromBase64(bytearray);QBuffer buffer(&Ret_bytearray);buffer.open(QIODevice::WriteOnly);QPixmap imageresult;imageresult.loadFromData(Ret_bytearray);return imageresult;} }; #endif // SBASE64TOIMAGE_H總結(jié)
以上是生活随笔為你收集整理的QTcpSocket客户端和服务端发送图片(或大文件)小Demo的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 2022年1~8月语音合成(TTS)和语
- 下一篇: 用数组实现一个队列改进版