语言 |解组任意数据
golang | unmarshalling arbitrary data
问题
有没有一种方法可以编组 JSON 数据,使其可以按部分/部分解组?
假设数据的上半部分是一个 "code",它将指示如何处理下半部分......例如根据 [=38= 将下半部分解组为特定结构].
有两个结构可以作为下半部分发送...
type Range Struct {
Start int
End int
}
type User struct {
ID int
Pass int
}
伪代码示例
它可能看起来像这样...
message := &Message{
Code: 4,
&Range {
Start: 1,
End: 10,
}
}
它可能看起来像这样...
message := &Message{
Code: 3,
&User {
ID: 1,
Pass: 1234,
}
}
因此,在解组数据时我可以...
// get code from top half
m := Message{}
err = json.UnMarshallTopHalf(byteArray, &m)
if m.Code == 4 {
// ok, the code was four, lets unmarshall into type Range
r := Range{}
json.UnmarshalBottomHalf(byteArray, &r)
}
我查看了 JSON & Go 以了解如何编组和解组定义的结构。我可以做到这一点,但我无法像上面的示例那样找到任意数据的方法...
type Message struct {
Code int `json:"cc"`
Range *Range `json:"vvv,omitempty"`
User *User `json:"fff,omitempty"`
}
然后给出代码== x,使用范围,如果是,使用用户。
您可以先在 json.RawMessage 中解组下半部分,例如
package main
import (
"encoding/json"
"fmt"
)
type Message struct {
Code int
Payload json.RawMessage // delay parsing until we know the code
}
type Range struct {
Start int
End int
}
type User struct {
ID int
Pass int
}
func MyUnmarshall(m []byte) {
var message Message
var payload interface{}
json.Unmarshal(m, &message) // delay parsing until we know the color space
switch message.Code {
case 3:
payload = new(User)
case 4:
payload = new(Range)
}
json.Unmarshal(message.Payload, payload) //err check ommited for readability
fmt.Printf("\n%v%+v", message.Code, payload) //do something with data
}
func main() {
json := []byte(`{"Code": 4, "Payload": {"Start": 1, "End": 10}}`)
MyUnmarshall(json)
json = []byte(`{"Code": 3, "Payload": {"ID": 1, "Pass": 1234}}`)
MyUnmarshall(json)
}
问题
有没有一种方法可以编组 JSON 数据,使其可以按部分/部分解组?
假设数据的上半部分是一个 "code",它将指示如何处理下半部分......例如根据 [=38= 将下半部分解组为特定结构].
有两个结构可以作为下半部分发送...
type Range Struct {
Start int
End int
}
type User struct {
ID int
Pass int
}
伪代码示例
它可能看起来像这样...
message := &Message{
Code: 4,
&Range {
Start: 1,
End: 10,
}
}
它可能看起来像这样...
message := &Message{
Code: 3,
&User {
ID: 1,
Pass: 1234,
}
}
因此,在解组数据时我可以...
// get code from top half
m := Message{}
err = json.UnMarshallTopHalf(byteArray, &m)
if m.Code == 4 {
// ok, the code was four, lets unmarshall into type Range
r := Range{}
json.UnmarshalBottomHalf(byteArray, &r)
}
我查看了 JSON & Go 以了解如何编组和解组定义的结构。我可以做到这一点,但我无法像上面的示例那样找到任意数据的方法...
type Message struct {
Code int `json:"cc"`
Range *Range `json:"vvv,omitempty"`
User *User `json:"fff,omitempty"`
}
然后给出代码== x,使用范围,如果是,使用用户。
您可以先在 json.RawMessage 中解组下半部分,例如
package main
import (
"encoding/json"
"fmt"
)
type Message struct {
Code int
Payload json.RawMessage // delay parsing until we know the code
}
type Range struct {
Start int
End int
}
type User struct {
ID int
Pass int
}
func MyUnmarshall(m []byte) {
var message Message
var payload interface{}
json.Unmarshal(m, &message) // delay parsing until we know the color space
switch message.Code {
case 3:
payload = new(User)
case 4:
payload = new(Range)
}
json.Unmarshal(message.Payload, payload) //err check ommited for readability
fmt.Printf("\n%v%+v", message.Code, payload) //do something with data
}
func main() {
json := []byte(`{"Code": 4, "Payload": {"Start": 1, "End": 10}}`)
MyUnmarshall(json)
json = []byte(`{"Code": 3, "Payload": {"ID": 1, "Pass": 1234}}`)
MyUnmarshall(json)
}