十年網(wǎng)站開(kāi)發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營(yíng)維護(hù)+專業(yè)推廣+無(wú)憂售后,網(wǎng)站問(wèn)題一站解決
json格式可以算我們?nèi)粘W畛S玫男蛄谢袷街涣?,Go語(yǔ)言作為一個(gè)由Google開(kāi)發(fā),號(hào)稱互聯(lián)網(wǎng)的C語(yǔ)言的語(yǔ)言,自然也對(duì)JSON格式支持很好。官方提供的Json解析包已經(jīng)非常強(qiáng)大,我們接下來(lái)講解Json的序列化與反序列化操作。另外還有一些第三方的Json解析庫(kù),也能夠高效的操作Json對(duì)象,比如simplejson,ffjson等。下面是兩個(gè)比較重要的函數(shù):
創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供宣威網(wǎng)站建設(shè)、宣威做網(wǎng)站、宣威網(wǎng)站設(shè)計(jì)、宣威網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)與制作、宣威企業(yè)網(wǎng)站模板建站服務(wù),十余年宣威做網(wǎng)站經(jīng)驗(yàn),不只是建網(wǎng)站,更提供有價(jià)值的思路和整體網(wǎng)絡(luò)服務(wù)。
? Json Marshal:將數(shù)據(jù)編碼成json字符串
Marshal 用于將struct對(duì)象序列化到j(luò)son對(duì)象中。v是interface{}類型,任何類型都實(shí)現(xiàn)了空接口。
1:tag中的第一個(gè)參數(shù)是用來(lái)指定別名,比如Name 指定別名為 username `json:"username"`
2:如果不想指定別名但是想指定其他參數(shù)用逗號(hào)來(lái)分隔,omitempty 指定到一個(gè)field時(shí),如果在賦值時(shí)對(duì)該屬性未賦值或者對(duì)該屬性賦值為 zero value,那么將Person序列化成json時(shí)會(huì)忽略該字段
3:- 指定到一個(gè)field時(shí),無(wú)論有沒(méi)有值,將Person序列化成json時(shí)都會(huì)忽略該字段
4:string 指定到一個(gè)field時(shí),比如Person中的Count為int類型 如果沒(méi)有任何指定在序列化到j(luò)son之后也是int 比如這個(gè)樣子 “Count”:0,但是如果指定了string之后序列化之后也是string類型的,那么就是這個(gè)樣子"Count":"0"
? struct序列化為Json
? slice序列化為Json
? map 序列化為Json
? Json Unmarshal:將json字符串解碼到相應(yīng)的數(shù)據(jù)結(jié)構(gòu),Unmarshal的第一個(gè)參數(shù)是[]byte,第二個(gè)參數(shù)是接受json解析的數(shù)據(jù)結(jié)構(gòu)。
下面我們依次講解Json的操作。
1:將Json序列化進(jìn)入結(jié)構(gòu)體
2::將Json序列化到結(jié)構(gòu)體slice
3:將Json序列化進(jìn)Map
4:將Json序列化進(jìn)Slice
后端開(kāi)發(fā)人員跟前端對(duì)接接口的時(shí)候,或多或少都會(huì)面臨一些溝通問(wèn)題,比如說(shuō)枚舉字符的定義,比如有整形狀態(tài)字段: state
通常給前端的時(shí)候,前段要做的是將1,2,3以及對(duì)應(yīng)的中文釋義存儲(chǔ)為key/value的形式,key與value單看都無(wú)法知道對(duì)方的語(yǔ)義,
比如我只知道狀態(tài)值為“1”, 是無(wú)法將其與“成功”對(duì)應(yīng)起來(lái)的(當(dāng)然這套狀態(tài)的設(shè)計(jì)者肯定是知道的),后端通常給到前端的restful api
接口定義也是key/value的形式,這乍一看其實(shí)也沒(méi)啥毛病,只要有key/value也沒(méi)問(wèn)題,后端定義通常會(huì)是
但數(shù)字的表現(xiàn)形式終歸是不不太明確的,如果對(duì)狀態(tài)的定義換成以下形式:
基本可以理解為中英文互譯了,理解起來(lái)也會(huì)更清晰一些不是,如果這么做的話,后端給到前端的響應(yīng)字段狀態(tài)的類型就需要修改成字符器格式
后端還是要做一層字符串到整型的轉(zhuǎn)換,從目的來(lái)講,我們只是想返給前端的 state 字段是字符串而已,也就是在做json序列化的時(shí)候?qū)⒄团c字符串做一層轉(zhuǎn)換,有更優(yōu)雅的做法如下所示
只需要做兩件事,自定義類型 MyState ,實(shí)現(xiàn) MarshalJSON 方法
只要類型實(shí)現(xiàn)了 MarshalJSON 方法,在json序列化時(shí)就會(huì)調(diào)用此方法,如此一來(lái),我們就輕松實(shí)現(xiàn)了自定義json序列化,反序列化同樣如此
實(shí)現(xiàn)起來(lái)也很簡(jiǎn)單
需要注意的是, UnmarshalJSON 方法操作過(guò)程需要給 receiver 也就是 u 賦值,所以必須是指針類型,同樣的,在實(shí)現(xiàn)
MarshalJSON 方法, receiver 的類型需要與結(jié)構(gòu)體定義中的類型保持一致,否則自定義序列化會(huì)失敗
參考:
json是一種經(jīng)常使用的數(shù)據(jù)格式,下面總結(jié)一下json的使用
json與struct轉(zhuǎn)換的話struct的屬性必須首字母大寫(xiě)。
當(dāng)用的多了就會(huì)發(fā)現(xiàn)一個(gè)致命的問(wèn)題:go默認(rèn)會(huì)將特殊字符轉(zhuǎn)義采用以下方法可以解決:
處理方法1
處理方法2
不管是屬性組成的還是Tag組成的json字符串,都可以正常的解析
tag:
json:"-" // 表示不進(jìn)行序列化
IsOnSale bool json:"is_on_sale,string" //序列化后轉(zhuǎn)成string
ProductID int64 json:"product_id,omitempty" //為零值時(shí)忽略
序列化或者反序列化時(shí)可以指定類型,支持string,number和boolean
IsOnSale bool json:"is_on_sale,string"
注意:
正確使用第一個(gè),第二個(gè)回報(bào)錯(cuò)
其實(shí)你的問(wèn)題在與最后一段是[]byte
如果直接轉(zhuǎn)json出來(lái)的數(shù)據(jù)是一個(gè)base64的字符串
所以你要做的應(yīng)該是把最后的這個(gè)[]byte按字符串直接輸出。
自己手動(dòng)轉(zhuǎn)一下吧。