概述:Protobuf-net是C#中高效的二进制序列化工具,以紧凑、跨语言支持和卓越性能著称。通过定义消息类型、序列化和反序列化实现数据传输,并可适用于Web接口。前端可使用protobuf.js库解析Protobuf格式数据。
Protobuf-net 在 C# 中的编码结构及使用方法
优点
Protobuf-net(Protocol Buffers)是一种高效的二进制序列化工具,具有以下优点:
- 高效紧凑: 生成的二进制数据体积小,传输效率高。
- 跨语言支持: 适用于多语言环境,实现了多语言间数据的无缝交互。
- 性能优越: 相比其他序列化方式,序列化和反序列化速度更快。
使用方法
1. 定义消息类型
使用 ProtoContract 和 ProtoMember 属性定义消息类型:
[ProtoContract]
public class Person {
[ProtoMember(1)]
public int Id { get; set; }
[ProtoMember(2)]
public string Name { get; set; }
[ProtoMember(3)]
public string Email { get; set; }
}
2. 序列化与反序列化
// 序列化
Person person = new Person { Id = 1, Name = "John Doe", Email = "john@example.com" };
using (MemoryStream stream = new MemoryStream()) {
Serializer.Serialize(stream, person);
byte[] serializedData = stream.ToArray();
// 将 serializedData 发送给其他系统或保存到文件
}
// 反序列化
byte[] receivedData = /* 从其他系统获取的数据 */;
using (MemoryStream stream = new MemoryStream(receivedData)) {
Person deserializedPerson = Serializer.Deserialize<Person>(stream);
// 使用 deserializedPerson 对象
}
注意事项
- 版本一致性: 序列化和反序列化的结构版本需一致,以免造成兼容性问题。
- 默认值: Protobuf 不会序列化默认值,需注意默认值可能导致的数据丢失。
是否适合 Web 接口使用
Protobuf-net 适用于 Web 接口,尤其是对于需要高性能和低带宽的场景。通过配置 Web API 或 gRPC 服务器,可以使用 Protobuf 格式进行数据传输。
前端JS调用和解析
前端可以使用protobuf.js库解析Protobuf格式的数据,以下是简单的示例:
<script src="https://cdn.jsdelivr.net/npm/protobufjs/dist/protobuf.min.js"></script>
<script>
// 加载Protobuf定义
protobuf.load("path/to/your/protofile.proto", function(err, root) {
if (err) throw err;
// 获取消息类型
var Person = root.lookupType("YourNamespace.Person");
// 解码二进制数据
var binaryData = /* 从服务器获取的二进制数据 */;
var message = Person.decode(binaryData);
// 使用解码后的消息对象
console.log(message);
});
</script>
在这个例子中,通过protobuf.js加载Protobuf定义,然后使用lookupType获取消息类型,最后通过decode方法解码服务器返回的二进制数据。得到解码后的消息对象后,可以在前端JS中方便地使用。