Qt基于TCP网络程序发包封包抽象
之前沒經(jīng)驗(yàn), 發(fā)送數(shù)據(jù)包的時(shí)候, 包頭包尾等信息都是通過重新定義一個(gè)結(jié)構(gòu)體實(shí)現(xiàn), 不同的協(xié)議包就有不同的結(jié)構(gòu)體, 結(jié)果導(dǎo)致這樣的現(xiàn)象: 有多少上層業(yè)務(wù)協(xié)議包, 我就分別重新定義一個(gè)對應(yīng)的加上包頭包尾的新的結(jié)構(gòu)體, 很費(fèi)勁.......額....
現(xiàn)在, 重新想了下, 一個(gè)改進(jìn)的方式, 把"封包"過程抽象出來, 使用Qt的QByteArray來操作流數(shù)據(jù)(還是挺方便的)
.h
#ifndef PACKET_H #define PACKET_H#include <QObject> #include <QByteArray>#define FrontPacket "KT" #define EndPacket "END"//把數(shù)據(jù)封包, 加上包頭包尾包長標(biāo)志校驗(yàn) class Packet : public QObject {Q_OBJECT public:explicit Packet(QObject *parent = 0);static QByteArray Pack(QByteArray data); //封包 };#endif // PACKET_H.cpp
#include "packet.h"Packet::Packet(QObject *parent) :QObject(parent) { }QByteArray Packet::Pack(QByteArray data) {QByteArray pack;pack.append(FrontPacket);quint32 len = 4 + data.size() + 4 + 3;pack.append(reinterpret_cast<const char*>(&len), 4);quint32 flag = 0;pack.append(reinterpret_cast<const char*>(&flag), 4);pack.append(data);quint32 crc = 0;pack.append(reinterpret_cast<const char*>(&crc), 4);pack.append(EndPacket);return pack; }?
然后, 在上層界面操作時(shí)候, 可以用定義好的上層協(xié)議結(jié)構(gòu)體對象直接轉(zhuǎn)成字節(jié)流QByteArray類型然后發(fā)往底層網(wǎng)絡(luò)的發(fā)送數(shù)據(jù)接口, 在底層發(fā)送數(shù)據(jù)接口中, send數(shù)據(jù)前, 先把傳進(jìn)來的協(xié)議數(shù)據(jù)包傳到上邊封裝好的靜態(tài)類成員Pack()中處理一下, 就可以把返回值直接send了
?
好處: 上層業(yè)務(wù), 只要封裝好上層協(xié)議數(shù)據(jù), 就可以調(diào)用網(wǎng)絡(luò)底層一個(gè)統(tǒng)一的發(fā)送數(shù)據(jù)接口進(jìn)行發(fā)包(本挫人之前這樣做:底層網(wǎng)絡(luò)提供了針對不同協(xié)議包有不同的接口方法, 然后每添加一條新協(xié)議, 就要添加一個(gè)成員函數(shù), 每刪刪除一條協(xié)議, 就要.....111111111111111111)
?
完.....................................................
?
轉(zhuǎn)載于:https://www.cnblogs.com/jianc/archive/2013/01/29/2881651.html
總結(jié)
以上是生活随笔為你收集整理的Qt基于TCP网络程序发包封包抽象的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Web开发的那点事--软件复用
- 下一篇: 当你辛辛苦苦写的博客文章被无情复制,成为