Heim >Backend-Entwicklung >Golang >Ist „google.protobuf.Struct' die optimale Wahl für das Senden von dynamischem JSON über gRPC?
Die Verwendung des Typs google.protobuf.Struct bietet eine effiziente Lösung zur Übertragung dynamischer JSON-Daten über GRPC. Betrachten Sie die folgende User.proto-Datei:
syntax = "proto3"; package messages; import "google/protobuf/struct.proto"; service UserService { rpc SendJson (SendJsonRequest) returns (SendJsonResponse) {} } message SendJsonRequest { string UserID = 1; google.protobuf.Struct Details = 2; } message SendJsonResponse { string Response = 1; }
Anujs Lösung:
Dieser Ansatz ist zwar funktionsfähig, aber etwas kompliziert:
var item = &structpb.Struct{ Fields: map[string]*structpb.Value{ "name": &structpb.Value{ Kind: &structpb.Value_StringValue{ StringValue: "Anuj", }, }, "age": &structpb.Value{ Kind: &structpb.Value_StringValue{ StringValue: "Anuj", }, }, }, }
Lukes Lösung:
Diese Methode ist prägnanter, umfasst aber mehrere Konvertierungen:
m := map[string]interface{}{ "foo":"bar", "baz":123, } b, err := json.Marshal(m) s := &structpb.Struct{} err = protojson.Unmarshal(b, s)
Empfohlene Lösung:
Der einfachste und effizienteste Ansatz besteht darin, die integrierten Funktionen des structpb-Pakets zu nutzen:
m := map[string]interface{}{ "name": "Anuj", "age": 23, } details, err := structpb.NewStruct(m) // Check for errors as per documentation if err != nil { panic(err) } userGetRequest := &pb.SendJsonRequest{ UserID: "A123", Details: details, }
Denken Sie daran, die in der structpb-Dokumentation angegebenen Konvertierungsregeln einzuhalten, um Fehler zu vermeiden.
Das obige ist der detaillierte Inhalt vonIst „google.protobuf.Struct' die optimale Wahl für das Senden von dynamischem JSON über gRPC?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!