Protobuf-net(Protocol Buffers)是一种高效的二进制序列化工具,具有以下优点:
使用 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; }
}
// 序列化
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-net 适用于 Web 接口,尤其是对于需要高性能和低带宽的场景。通过配置 Web API 或 gRPC 服务器,可以使用 Protobuf 格式进行数据传输。
前端可以使用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中方便地使用。