protobuf的bytes类型

栏目: 服务器 · 发布时间: 7年前

内容简介:python:Android(kotlin):golang
syntax "proto3";
package  Test;

service Test{
    rpc KeepAlive(Hello) returns (Hello){}
}

message Hello{
   int64 timestamp=1;
   bytes alert=2;
}

python:

channel = grpc.insecure_channel('%s:%d'%(ADDR, PORT))
  stub = Test_pb2_grpc.TestStub(channel=channel)
  hello = Hello()
  hello.timestamp=datetime.now().timestamp()
  hello.alert=bytes("hello", encoding="ascii")

  ret = stub.KeepAlive(hello)
  print(ret.alert.decode("ascii"))

Android(kotlin):

val channel = ManagedChannelBuilder.forAddress(ADDR, PORT)
                .usePlaintext(true)
                .build()

  synchronized(this){
            if(channel.isShutdown || channel.isTerminated){
                  val channel = ManagedChannelBuilder.forAddress(ADDR, PORT)
                        .usePlaintext(true)
                        .build()
            }

            val stub = TestGrpc.newBlockingStub(channel)
        }
    var hello = Hello()
    hello.timestamp = (Date().time/1000).toInt()
    hello.alert = ByteString.copyFrom("hello".toByteArray())
    val ack = stub!!.KeepAlive(hello)
    println(ByteString.copyTo(ack.alert).toString())

golang

conn, err := grpc.Dial(ADDRESS, grpc.WithInsecure())
    if err != nil {
        log.Fatal(err)
    }
    defer conn.Close()
    c := pb.NewTestClient(conn)
    ctx := context.Background()
    
    hello := pb.Hello{
        Timestamp:time.Now().Unix(),
        Alert:[]byte("hello"),
    }
    ack, err:= c.KeepAlive(ctx, &hello)
    if err!=nil{
        log.Fatal(err)
    }
    fmt.Println(string(ack.Alert))

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

信息规则

信息规则

[美] 卡尔・夏皮罗(Carl Shapiro)、[美] 哈尔・瓦里安(Hal Varian) / 张帆 / 中国人民大学出版社 / 2000-6 / 33.00元

本书的目标是,运用网络经济中的经济学知识,从经济研究和作者自己的经验中提取出适合信息相关产业的经理们的知识。本书描述的思想、概念、模型和思考方法会帮助读者作出更好的决策。一起来看看 《信息规则》 这本书的介绍吧!

html转js在线工具
html转js在线工具

html转js在线工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具