ASP.NET Core中使用Protobuf从入门到实战

一、Protocol Buffers简介和特点

1、Protocol Buffers简介

ProtoBuf (Google Protocol Buffer)是由google公司用于数据交换的序列结构化数据格式,具有跨平台、跨语言、可扩展特性,类型于常用的XML及JSON,但具有更小的传输体积、更高的编码、解码能力,特别适合于数据存储、网络数据传输等对存储体积、实时性要求高的领域。 

2、Protocol Buffers特点

        XML、JSON是目前常用的数据交换格式,它们可读性较好。但序列化后的数据字节很大,序列化和反序列化的时间较长,数据传输效率不高。

        Protobuf和Xml、Json序列化的方式不同,采用了二进制字节的序列化方式,用字段索引和字段类型通过算法计算得到字段之前的关系映射,从而达到更高的时间效率和空间效率,特别适合对数据大小和传输速率比较敏感的场合使用。


 

二、Protobuf协议文件(proto3)指南

ProtoBuf 有两个语言版本:v2 与 v3,截止目前在使用 v3 的时候,需要在 *.proto 文件首行中明文标识syntax="proto3";
否则默认为 syntax="proto2"; 推荐使用最新的syntax = "proto3";语法。

三、如何将.proto文件生成C#类文件

1、方法一:protogen - npm cnmp  install -g protogen
https://www.npmjs.com/package/protogen

语法:protogen -i:input.proto -o:output.cs 

方法二:通过源码编译C# protogen 
下载地址:https://github.com/protobuf-net/protobuf-net/tags 

方法三:Protogen官网是支持在线生成的。 
网址 : https://protogen.marcgravell.com/ 

四、ASP.NET Core中使用Protobuf格式作为数据交换

1、请求=》PB》反序列化为对象—请求数据

2、响应=》响应的数据》序列化为PB格式 

五、NET Core客户端调用Protobuf格式的WebApi

protobuf-net/protobuf-net: Protocol Buffers library for idiomatic .NET 

 https://github.com/protobuf-net/protobuf-net

作者:阿笨

      【官方QQ一群:跟着阿笨一起玩NET(已满)】:422315558跟着阿笨一起玩NET

      【官方QQ二群:跟着阿笨一起玩C#(已满)】:574187616跟着阿笨一起玩C#

      【官方QQ三群:跟着阿笨一起玩ASP.NET(已满)】:967920586跟着阿笨一起玩ASP.NET

      【官方QQ四群:Asp.Net Core跨平台技术开发(可加入)】:806491485Asp.Net Core跨平台技术开

      【官方QQ五群:.NET Core跨平台开发技术(可加入)】:1036896405.NET Core跨平台开发技术

      【网易云课堂】:https://study.163.com/provider/2544628/index.htm?share=2&shareId=2544628

      【腾讯课堂】:https://abennet.ke.qq.com

      【51CTO学院】:https://edu.51cto.com/sd/66c64

      【微信公众号】:http://dwz.cn/ABenNET

原文地址:https://www.cnblogs.com/51net/p/14320332.html