应用层自定义协议与序列化

关于协议

在了解UDP和TCP的代码后,我们发现,我们想传输数据,都是按照字符串的形式发送,然后根据识别字符串得到相应信息,但如果我们想传输结构化的数据该怎么办呢?

如果我们双方约定一种协议,规定该结构中每一个字段分别代表什么意思,然后把相应数据打包成结构体然后传输给对方,对方收到后再依次解开获取各个信息即可。因此协议就是双方约定好的结构化的数据。

这里存在一个问题,我们是否可以直接把结构体发送给对方?不可以,如果两个机器不同,可能会导致发送和收到的信息不一致。因此我们需要做一下改进。

序列化与反序列化

如果我们规定,在发送时按照一定规则把结构体转换成字符串,然后收到字符串时再按照相应的规则转换回去,即可保证信息的准确性,这个过程就为序列化。把字符串反向转换称为反序列化。

为什么要有序列化?------把信息多变一,方便网络发送。

无论采用什么方案,只要保证,一端发送时构造的数据, 在另一端能够正确的进行解析,就是ok的.这种约定,就是应用层协议。上述转换成字符串的"协议"已是被广泛运用的。

利用TCP+网络制定网络计算器

tcp和网络部分我们已经掌握,关键在于定好协议与加入序列化和反序列化的方案。

初步想法:在客户端封装一个请求类,有两个整数和一个char类型的运算符,在服务器端封装一个回应类,有一个结果和一个错误码(用于记录计算情况)。

序列化的方案:1.自己做,把结构体所有都转换成字符串传输。2.前人栽树,我们乘凉,用现有的方案,比如xml、json、protobuf等,为了增加可读性,我们选择json。即把我们的结构化数据转换成json方案的字符串。

同时,为了保证面向字节流下收取数据的完整性,我们在json串前加一个串的长度+\n作为报头,当读取完长度headlength即可读取整个报文不会造成数据丢失问题。

关于如何利用json进行序列化与反序列化,在这里给一份demo代码即可,如果需要的话让大模型生成即可。

cpp 复制代码
bool Serialize(std::string &out_string)//序列化
    {
        Json::Value root;
        root["x"] = _x;
        root["y"] = _y;
        root["oper"] = _oper;
        Json::StreamWriterBuilder wb;
        std::unique_ptr<Json::StreamWriter> w(wb.newStreamWriter());
        std::stringstream ss;
        w->write(root, &ss);
        out_string = ss.str();
        return true;
    }
    bool Deserialize(std::string &in_string)//反序列化
    {
        Json::Value root;
        Json::Reader reader;
        bool parsingSuccessful = reader.parse(in_string, root);
        if (!parsingSuccessful)
        {
            std::cout << "Failed to parse JSON\n";
            return false;
        }
        _x = root["x"].asInt();
        _y = root["y"].asInt();
        _oper = root["oper"].asInt();
        return true;
    }
相关推荐
羑悻的小杀马特3 分钟前
【Linux篇章】再续传输层协议UDP :从低可靠到极速传输的协议重生之路,揭秘无连接通信的二次进化密码!
linux·运维·服务器·后端·网络协议·udp
阿雄不会写代码2 小时前
wecross 报错这个文件找不到 tassl-1.1.1b-linux-x86_64.tar.gz
linux·运维·服务器
fuyongliang1233 小时前
Linux shell 脚本基础 003
java·服务器·前端
007php0078 小时前
Go 错误处理:用 panic 取代 err != nil 的模式
java·linux·服务器·后端·ios·golang·xcode
Frank Underwood_P8 小时前
零信任网络(1)
网络
爱奥尼欧9 小时前
【Linux】系统部分——ELF文件格式与动态库加载
linux·运维·服务器
一匹电信狗11 小时前
【C++】C++11新特性第一弹(列表初始化、新式声明、范围for和STL中的变化)
服务器·开发语言·c++·leetcode·小程序·stl·visual studio
一袋米扛几楼9812 小时前
【物联网】MQTT / Broker / Topic 是什么?
网络·物联网
AI浩13 小时前
Transformer架构三大核心:位置编码(PE)、前馈网络(FFN)和多头注意力(MHA)。
网络·深度学习·transformer
monster_风铃13 小时前
神州数码VRRP 原理与配置篇
网络·智能路由器