前端js实现protobuf序列化与反序列化

本文档详细介绍了如何在前端使用JavaScript实现Protocol Buffers (protobuf)的序列化和反序列化。首先,讲解了环境配置,包括下载protobuf 3.20版本并安装。接着,说明了如何编写.proto文件,然后通过特定命令进行编译。最后,展示了如何生成可在浏览器中使用的JS文件,并提供了前端使用的代码示例,通过控制台查看序列化和反序列化的结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

系列文章目录

websocket训练地址:https://www.qiulianmao.com,正在搭建中




1. 环境配置

  1. B站视频教学地址地址链接
  2. 下载3.20版本的protoc.exe地址链接
  3. 安装nodejshttps://nodejs.org/en
  4. 创建项目后执行
node -v(显示版本则说明安装成功)
npm install -g require(对库文件的引用库)
npm install -g browserify(这个是用来打包成前端使用的js文件)
npm install google-protobuf(安装google库)
  1. 项目目录总览
    在这里插入图片描述

2. 编写proto文件

新建case.proto文件

syntax = "proto3";
message Request{
   repeated Headers Headers= 5;
   string ContentEncoding = 6;
   string ContentType = 7;
   bytes Payload = 8;
}


message Headers{
   string Key = 1;
   string Value = 2;
}

3. 对proto文件进行编译

cmd中执行

.\protoc --js_out=import_style=commonjs,binary:. case.proto

项目新建main.js文件

var MessageBody = require('./case_pb');
module.exports = {
    DataProto: MessageBody
}

4. 生成前端可用的js文件

cmd中执行,会借助main.js生成case.js,这个就可以直接在浏览器中使用了。

browserify main.js > case.js

前端代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
  <script type="text/javascript" src="case.js"></script>
</head>
<body>
<script>
    let a = new proto.Request()
    let b = new proto.Headers()
    b.setKey('User-Agent')
    b.setValue('Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/118.0.0.0 Safari/537.36 Edg/118.0.2088.46')
    a.addHeaders(b)
    let c = new proto.Headers()
    c.setKey('Content')
    c.setValue('gzip')
    a.addHeaders(c)
    a.setPayloadtype('utf-8')
    console.log(a.toObject())
    let d = a.serializeBinary()
    console.log(d)
    let e = new proto.Request.deserializeBinary(d)
    console.log(e.toObject())
</script>
</body>
</html>

控制台查看结果
在这里插入图片描述

using System; //需要用到MemoryStream using System.IO; using UnityEngine; //引入ProtoBuf命名空间 using ProtoBuf; /// /// 测试类 /// public class TestProtobuf : MonoBehaviour { /// /// 用于测试的数据类 /// [ProtoContract] //声明这个类能被序列化 public class UserData { //声明每一个需要被序列化的成员,编号从1开始 [ProtoMember(1)] public int id; [ProtoMember(2)] public string name; [ProtoMember(3)] public int level; } //测试代码 void Start() { //将要被序列化的UserData示例 UserData user1 = new UserData (); user1.id = 1; user1.name = "User1"; user1.level = 10; //打印user1 Debug.Log (string.Format ("user1-> id:{0}, name:{1}, level:{2}", user1.id, user1.name, user1.level)); //序列化 byte[] buff = null; using (MemoryStream ms = new MemoryStream ()) { Serializer.Serialize (ms, user1); ms.Position = 0; int length = (int)ms.Length; buff = new byte[length]; ms.Read (buff, 0, length); } //输出字节数组 Debug.Log (string.Format("Serialized data-> {0}", BitConverter.ToString(buff))); //反序列化 UserData user2 = default(UserData); using (MemoryStream ms = new MemoryStream (buff)) { user2 = Serializer.Deserialize (ms); } //打印反序列化生成的user2 Debug.Log (string.Format ("user2-> id:{0}, name:{1}, level:{2}", user2.id, user2.name, user2.level)); } } 作者:qufangliu 链接:https://www.jianshu.com/p/d9be1b3d2446 來源:简书 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

互动创客坊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值