Memperluaskan Pilihan Penghuraian Boolean dalam JSON Unmarshaling
Apabila memetakan output perkhidmatan yang mengaburkan garis antara jenis boolean dan nilai lain, JSON yang lebih akomodatif parser menjadi penting. Fungsi pengekodan/json unmarshal terbina dalam kurang dalam hal ini, mendorong carian untuk alternatif penghuraian permisif.
Satu pendekatan ialah mencipta fungsi UnmarshalJSON tersuai untuk jenis yang diingini. Fungsi ini boleh menentukan peraturan penghuraian tersuai untuk mengendalikan nilai boolean yang tidak jelas. Sebagai contoh, pertimbangkan jenis ConvertibleBoolean berikut:
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 }
Dalam fungsi ini, rentetan "1" dan "true" dipetakan kepada benar, manakala "0" dan "false" dihuraikan sebagai palsu. Nilai di luar julat ini mencetuskan ralat.
Untuk menggunakan penghuraian boolean tersuai ini, gunakan teg json pada medan sasaran. Contohnya:
type MyType struct { AsBoolean ConvertibleBoolean `json:"field1"` AlsoBoolean ConvertibleBoolean `json:"field2"` }
Dengan peraturan penghuraian tersuai ini disediakan, input JSON:
{ "field1": true, "field2": 1 }
Akan menghasilkan struct unmarshaled berikut:
obj := MyType{} json_err := json.Unmarshal([]byte(input_json), &obj) fmt.Printf("%v\n", obj.AsBoolean) //"true" fmt.Printf("%v\n", obj.AlsoBoolean) //"true"
Oleh memanfaatkan fungsi penghuraian tersuai, anda memperoleh fleksibiliti dalam pembongkaran JSON, membolehkan anda mengendalikan nilai boolean yang tidak jelas sebagai diperlukan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyesuaikan JSON Unmarshaling untuk Mengendalikan Nilai Boolean Ambiguous?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!