从 JSON 中解组包含 0 和 False 的布尔值
解析 JSON 数据需要仔细考虑数据类型以避免误解。在服务将布尔值交换为 0 和 false(以及 1 和 true)的情况下,实现正确的解组变得至关重要。
内置的编码/json 包提供了一种使用自定义类型自定义解组过程的方法。通过定义自定义类型,您可以实现定制的解组逻辑来处理所需的转换。
自定义解组类型
创建实现 json.Unmarshaler 接口的自定义类型。此类型将负责将 JSON 数据转换为所需的布尔格式。
type ConvertibleBoolean bool func (bit *ConvertibleBoolean) UnmarshalJSON(data []byte) error { asString := string(data) if asString == "1" || asString == "true" { *bit = true } else if asString == "0" || asString == "false" { *bit = false } else { return errors.New(fmt.Sprintf("Boolean unmarshal error: invalid input %s", asString)) } return nil }
在此示例中,ConvertibleBoolean 是实现 json.Unmarshaler 接口的自定义布尔类型。它会覆盖默认的 JSON 解组过程,并将传入数据检查为字符串。如果它标识了表示 true 或 false 的字符串(或其对应的数字 1 和 0),则会相应地设置 ConvertibleBoolean 值。否则,将返回错误。
使用自定义类型
现在您已经有了自定义解组类型,可以在结构体中使用它来定义预期的 JSON 结构。
type MyType struct { AsBoolean ConvertibleBoolean `json:"field1"` AlsoBoolean ConvertibleBoolean `json:"field2"` }
示例解组
使用自定义类型后,您可以将 JSON 数据解组为 MyType 结构,将 0 和 false(以及 1 和 true)正确转换为布尔值。
input_json := `{ "field1" : true, "field2" : 1 }` obj := MyType{} json_err := json.Unmarshal([]byte(input_json), &obj) fmt.Printf("%v\n", obj.AsBoolean) //"true" fmt.Printf("%v\n", obj.AlsoBoolean) //"true"
此示例 JSON 数据包含“true”和“1”,默认解组器会将其视为不同类型。然而,通过使用 ConvertibleBoolean,这两个值都被正确地解组为 true。
以上是如何使用'0”和'false”(以及'1”和'true”)处理 JSON 的布尔解组?的详细内容。更多信息请关注PHP中文网其他相关文章!