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
相关文章
- ASP.NET Core使用静态文件、目录游览与MIME类型管理
- ASP .Net Core系统部署到Ubuntu 16.04 具体方案
- ASP.NET Core基于SignalR实现消息推送实战演练
- asp.net core signalr Error: Failed to start the transport 'WebSockets': null
- ASP.NET使用ViewBag和HttpPost在MVC中进行基本数据类型的数据传递Demo
- ASP.NET MVC案例——————拦截器
- 【ASP.NET Core】依赖注入高级玩法——如何注入多个服务实现类
- 重新整理asp.net core 实操篇——简介
- 全国疫情精准定点动态更新(.net core)
- ASP.NET Core 6框架揭秘实例演示[28]:自定义一个服务器
- ASP.NET Core 6框架揭秘实例演示[04]:自定义依赖注入框架
- 用最简单的方式在ASP.NET Core应用中实现认证、登录和注销
- [ASP.NET Core 3框架揭秘]服务承载系统[6]: 承载服务启动流程[下篇]
- [ASP.NET Core 3框架揭秘] Options[5]: 依赖注入
- ASP.NET Core 3框架揭秘] 配置[8]:多样化的配置源[下篇]
- ASP.NET Core应用针对静态文件请求的处理[1]: 以Web的形式发布静态文件
- ASP.NET Core管道深度剖析(3):管道是如何处理HTTP请求的?
- ASP.NET Core的配置(5):配置的同步[设计篇]
- ASP.NET Web Forms - Repeater 控件
- ASP.NET Web Forms - Hashtable 对象
- asp.net打印网页后自动关闭网页【无需插件】
- ASP.NET常见内置对象(一)
- Asp.net core中间件实现原理及用法解说
- asp.net core webapi验证
- ASP.NET_数据缓存理论