Heim >Backend-Entwicklung >Golang >Wie kann das Problem mit Nulldatenfeldern beim Unmarshaling von JSON in die Protobuf-Struktur gelöst werden?
Unmarshaling von JSON in ein Protobuf-Strukturfeld: Behebung des Datenfeld-Null-Problems
Beim Versuch, JSON-Daten in ein Protobuf-Strukturfeld vom Typ „google“ zu entmarshalieren .protobuf.Value, kann es vorkommen, dass das Datenfeld in der protobuf-Struktur auf Null gesetzt ist. Dieses Problem entsteht aufgrund der Inkompatibilität zwischen dem Encoding/JSON-Paket der Standardbibliothek und den spezifischen Anforderungen der Protobuf-Wertfelder.
Um dieses Problem zu lösen, sollte eine besser geeignete Bibliothek für das Unmarshaling verwendet werden. Die Protobuf-Bibliothek von Google bietet einen robusteren und maßgeschneiderten Ansatz für den Umgang mit Protobuf-spezifischen Datentypen. Hier ist der korrigierte Code mit protojson.Unmarshal:
<code class="go">import ( "google.golang.org/protobuf/encoding/protojson" "google.golang.org/protobuf/proto" "io" ) req := &proto.JobCreateRequest{} bytes, err := io.ReadAll(r.Body) if err != nil { return err } err = protojson.Unmarshal(bytes, req) if err != nil { return err }</code>
Durch die Nutzung von protojson.Unmarshal anstelle des Encoding/Json-Pakets können Sie die JSON-Daten effektiv in die Protobuf-Struktur konvertieren und so sicherstellen, dass das Datenfeld korrekt ist besiedelt. Die resultierende JobCreateRequest-Struktur enthält die erwarteten Werte für den Namen, die Beschreibung und die Datenfelder.
Das obige ist der detaillierte Inhalt vonWie kann das Problem mit Nulldatenfeldern beim Unmarshaling von JSON in die Protobuf-Struktur gelöst werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!