首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Go Protobuf中的Protobuf和解编组

Go Protobuf中的Protobuf和解编组
EN

Stack Overflow用户
提问于 2021-08-05 13:16:29
回答 1查看 1.2K关注 0票数 0

我需要从python发送一个protobuf消息到Go系统。在python端,我调用SerializeToString()并将这个字符串作为http响应的主体发送。在项目的go方面,我在读取响应体后调用Unmarshal()。但是当我这样做时,我会得到proto: cannot parse invalid wire-format data错误。

请注意,反过来,当我从Go发送请求到Python时,Go中的请求封送和Python中的解封处理都可以正常工作。

有什么想法吗?谢谢

EN

回答 1

Stack Overflow用户

发布于 2021-08-05 15:36:39

Python函数是一种为原型消息创建二进制编码的字符串表示的方法,例如,SerializeToString(),但是将消息写入文件,但,这不是通过线路发送消息的方式。

你有一个Golang客户端和一个Python服务器?

Golang客户端应该调用服务方法。某种形式:

代码语言:javascript
复制
resp,err := client.SomeMethod(ctx,&pb.SomeMethodRequest{...})

Python服务器应该有服务方法的实现。某种形式:

代码语言:javascript
复制
def SomeMethod(self, request, context)

注意: gRPC确保在Golang客户机上传递给SomeMethod&pb.SomeMethodRequest{...}在Python方法中以request的形式出现。

在客户机和服务器中,您将使用protoc编译器生成的Golang类型和Python类(例如,protoc)。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68667326

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档