비동질 JSON 데이터 역마샬링
이 문의는 특정 섹션을 선택적으로 역마샬링할 수 있는 메커니즘을 활용하여 JSON 데이터를 효율적으로 역마샬링하는 데 중점을 둡니다. 또는 세그먼트. 목표는 첫 번째 부분이 뒷부분에 포함된 데이터 유형을 결정하는 "코드" 역할을 하는 JSON 구조를 처리하는 것입니다.
여러 데이터 구조가 있는 시나리오를 상상해 보세요.
type Range struct {
Start int
End int
}
type User struct {
ID int
Pass int
}
그리고 JSON 메시지에는 "페이로드" 필드에 어떤 데이터가 있는지 알려주는 "코드" 필드가 있습니다.
{
"Code": 4,
"Payload": {
"Start": 1,
"End": 10
}
}
{
"Code": 3,
"Payload": {
"ID": 1,
"Pass": 1234
}
}
"코드" 필드를 기반으로 "페이로드" 필드를 적절한 데이터 구조로 역마샬링해야 합니다.
솔루션
키 여기서는 json.RawMessage 유형을 사용하여 해당 유형을 알 때까지 "페이로드" 필드의 정렬 해제를 지연하는 것입니다. 예:
package main
import (
"encoding/json"
"fmt"
)
type Message struct {
Code int
Payload json.RawMessage // Delay parsing until we know the code
}
// Unmarshall into appropriate structures based on Code
func unmarshal(m []byte) error {
var message Message
err := json.Unmarshal(m, &message)
if err != nil {
return err
}
switch message.Code {
case 3:
var user User
if err := json.Unmarshal(message.Payload, &user); err != nil {
return err
}
fmt.Printf("Unmarshalled a User: %#v\n", user)
case 4:
var range Range
if err := json.Unmarshal(message.Payload, &range); err != nil {
return err
}
fmt.Printf("Unmarshalled a Range: %#v\n", range)
default:
return fmt.Errorf("unknown code: %d", message.Code)
}
return nil
}
func main() {
json1 := []byte(`{"Code": 3, "Payload": {"ID": 1, "Pass": 1234}}`)
if err := unmarshal(json1); err != nil {
fmt.Printf("error: %v\n", err)
}
json2 := []byte(`{"Code": 4, "Payload": {"Start": 1, "End": 10}}`)
if err := unmarshal(json2); err != nil {
fmt.Printf("error: %v\n", err)
}
}
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3