1. 說明
僅做了粗略的測(cè)試拘泞,不保證嚴(yán)謹(jǐn)性,但足以體現(xiàn)效果逞怨。
2. 測(cè)試
type T struct {
Field1 string `json:"tEst1"` // test json tag
FiEld2 string `bson:"test2"` // test non-json tag
Field3 string `json:"teSt3"` // test ignore json tag
Field4 string // test mismatched field
field5 string // test not export
}
testJson := "{\"test1\": \"test json tag\", \"fIeLd2\": \"test non-json tag and ignore case\", \"Field3\":\"test ignore json tag\", \"Field\":\"test mismatched field\", \"field5\":\"test not export\"}"
bytes := []byte(testJson)
testT := T{}
err := json.Unmarshal(bytes, &testT)
if err != nil {
fmt.Println("err:", err)
}
// 打印輸出捌省,有 json tag 的按照 json tag 比較碘橘,無 json tag 的按照字段名比較互订,比較不區(qū)分大小寫,為導(dǎo)出字段和未匹配通過的字段忽略
fmt.Printf("%++v\n", testT) // {Field1:test json tag FiEld2:test non-json tag and ignore case Field3: Field4: field5:}
testT = T{
Field1: "test field use tag",
FiEld2: "test non-json tag",
Field3: "test field use tag",
Field4: "test no tag",
field5: "test not export",
}
str, err := json.Marshal(testT)
// 輸出轉(zhuǎn)換的 json 字符串無未導(dǎo)出字段痘拆,無 tag 和非 json tag 字段使用字段名
fmt.Println(string(str)) // {"tEst1":"test field use tag","FiEld2":"test non-json tag","teSt3":"test field use tag","Field4":"test no tag"}
3. 結(jié)論
-
不區(qū)分大小寫
golang 結(jié)構(gòu)體(以下簡(jiǎn)稱 struct)字段名稱仰禽、struct tag(以下簡(jiǎn)稱 tag)、和 json 字符串(以下簡(jiǎn)稱 json)中的字段名之間不區(qū)分大小寫纺蛆,互相轉(zhuǎn)換時(shí)吐葵,會(huì)優(yōu)先檢測(cè)是否存在 json 的 tag(且僅限于 json 的 tag),如果存在則優(yōu)先和 tag 比較桥氏,未導(dǎo)出字段不參與轉(zhuǎn)換温峭。- struct -> json
生成的字符串會(huì)優(yōu)先使用 tag 作字段名,否則使用 struct 的字段名识颊。 - json -> struct
json 字符串會(huì)優(yōu)先按 json 的 tag 進(jìn)行不區(qū)分大小寫的匹配诚镰,如果匹配失敗則忽略該字段奕坟;如果沒有 json tag祥款,則會(huì)按 struct 的字段名進(jìn)行不區(qū)分大小寫的匹配。
- struct -> json