婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 解決golang json解析出現(xiàn)值為空的問題

解決golang json解析出現(xiàn)值為空的問題

熱門標(biāo)簽:重慶慶云企業(yè)400電話到哪申請 宿遷便宜外呼系統(tǒng)代理商 地圖標(biāo)注免費(fèi)定制店 上海極信防封電銷卡價格 不封卡外呼系統(tǒng) 鄭州智能語音電銷機(jī)器人價格 仙桃400電話辦理 湛江crm外呼系統(tǒng)排名 寧波語音外呼系統(tǒng)公司

我是通過beego框架,將請求過來的json進(jìn)行解析,并將值保存在結(jié)構(gòu)體中

--------------------1---------------------
 request := UpdateCommentRequestData{}
 req := common.Request{Data: request}
 err := json.Unmarshal(controller.Ctx.Input.RequestBody, req)
------------------------------------------

其中 UpdateCommentRequestData的結(jié)構(gòu)是這樣的

type UpdateCommentRequestData struct {
 Id []string `json:"id"`
}

common.request的結(jié)構(gòu)是這樣的

type Request struct {
 UserId uint64 `json:"userId,string"`
 Data interface{} `json:"data"`
}

我使用1中的代碼進(jìn)行解析,發(fā)現(xiàn)request.Id的值是空的,但是傳來的json是存在Id值的,當(dāng)時一頭霧水,就不斷在日志中打印,后來定位到是數(shù)據(jù)類型存在問題,

在1中的代碼里面,Data字段傳的是request的值,是值的拷貝,也就是說,json解析后的數(shù)據(jù)并不是賦值到reques中,所以使用request.Id并不會取到值,

如果將代碼改成這樣,再使用request.Id就可以取到值了

req := common.Request{Data: request},

補(bǔ)充:golang Unmarshal拿不全數(shù)據(jù)問題

說明:這個問題出現(xiàn)在后端調(diào)用json.Unmarshal方法去解析數(shù)據(jù)庫中存的數(shù)據(jù)時,解析出來的結(jié)果中只能拿到部分?jǐn)?shù)據(jù),json格式經(jīng)檢查后正確無誤,同時也沒有字段名出錯等低級錯誤。

首先來看要解析后的go結(jié)構(gòu)體

type ParamConfig struct {
 //標(biāo)識Id
 Id  string
 //抓拍目標(biāo)參數(shù)配置
 SnapObjConfig *SnapObjConfig
 //默認(rèn)去重參數(shù)配置
 DefaltDeweightConfig *DefaltDeweightConfig
}
//抓拍目標(biāo)參數(shù)結(jié)構(gòu)
type SnapObjConfig struct {
 //分辨率參數(shù)
 Distinguish *Distinguish
 //機(jī)動車配置
 vehicle *DataConfig
 //非機(jī)動車配置
 nonmotor *DataConfig
 //行人配置
 pedestrian *DataConfig
 //人臉配置
 face *DataConfig
}
//分辨率結(jié)構(gòu)
type Distinguish struct {
 //分辨率值
 DistinguishRate int32
}
 
type DataConfig struct {
 //最小寬度
 MinWeight int32
 //最小高度
 MinHight int32
}
//默認(rèn)去重參數(shù)結(jié)構(gòu)
type DefaltDeweightConfig struct {
 vehicle *DeweightNum
 nonmotor *DeweightNum
 pedestrian *DeweightNum
 face *DeweightNum
}
//默認(rèn)參數(shù)值結(jié)構(gòu)
type DeweightNum struct {
 Number float32
}

先向數(shù)據(jù)庫中插入一條需要解析的數(shù)據(jù)

SQL語句如下所示:

INSERT INTO "public"."sys_config"("config_key", "config_value") VALUES ('param_config', '[{"Id":"8149aa8e-1466-469b-ac5e-b0ea72f96129","SnapObjConfig":{"Distinguish":{"DistinguishRate":270},"vehicle":{"MinWeight":128,"MinHight":128},"nonmotor":{"MinWeight":32,"MinHight":64},"pedestrian":{"MinWeight":32,"MinHight":64},"face":{"MinWeight":40,"MinHight":40}},"DefaltDeweightConfig":{"vehicle":{"Number":0.95},"nonmotor":{"Number":0.95},"pedestrian":{"Number":0.95},"face":{"Number":0.95}}}]');

為了方便說明下面在代碼中打上詳細(xì)的log,大碼如下:

func (this *CommonController)GetParamConfig(c *gin.Context) {
 searchResp := models.SearchResp{
 Code: models.ApiStatus_SUCCESS,
 Msg: "successs",
 }
 retParamConfig := make([]*ParamConfig, 0)
 if configs, err := db_model.SysConfigsByConfigKey(this.DB, ParamConfigKey); err != nil  !models.IsEmptyResults(err){
 glog.Infoln(err)
 searchResp.Code = models.ApiStatus_ERROR
 searchResp.Msg = "fail"
 c.JSON(http.StatusInternalServerError, searchResp)
 return
 } else if len(configs) > 0 {
 glog.Infoln("data----------------", configs[0].ConfigValue)
 if err := json.Unmarshal([]byte(configs[0].ConfigValue), retParamConfig); err != nil {
 glog.Errorln(err)
 searchResp.Code = models.ApiStatus_ERROR
 searchResp.Msg = err.Error()
 c.JSON(http.StatusInternalServerError, searchResp)
 return
 }
 }
 searchResp.Data = retParamConfig
 glog.Infoln("retParamConfig[0].SnapObjConfig.Vehicle----------", retParamConfig[0].SnapObjConfig.vehicle)
 glog.Infoln("retParamConfig[0].SnapObjConfig.nonmotor-----------", retParamConfig[0].SnapObjConfig.nonmotor)
 glog.Infoln("retParamConfig[0].SnapObjConfig.pedestrian------------", retParamConfig[0].SnapObjConfig.pedestrian)
 glog.Infoln("retParamConfig[0].SnapObjConfig.Fsce------------------", retParamConfig[0].SnapObjConfig.face)
 glog.Infoln("retParamConfig[0].DefaltDeweightConfig.Fsce------------------", retParamConfig[0].DefaltDeweightConfig.face)
 glog.Infoln("retParamConfig[0].DefaltDeweightConfig.Fsce------------------", retParamConfig[0].DefaltDeweightConfig.vehicle)
 glog.Infoln("retParamConfig[0].DefaltDeweightConfig.Fsce------------------", retParamConfig[0].DefaltDeweightConfig.nonmotor)
 glog.Infoln("retParamConfig[0].DefaltDeweightConfig.Fsce------------------", retParamConfig[0].DefaltDeweightConfig.pedestrian)
 
 c.JSON(http.StatusOK, searchResp)
}

運(yùn)行之后如圖所示:

很明顯從一開始我們就向數(shù)據(jù)庫中存入了數(shù)據(jù),同時從日志中可以看出,data中存的是去數(shù)據(jù)庫中獲取的數(shù)據(jù),數(shù)據(jù)和剛開始存入到數(shù)據(jù)庫中的值一樣,但是調(diào)用unmarshal之后卻獲取不到全部的數(shù)據(jù),可以看一下使用postman調(diào)用接口之后的返回結(jié)果如下:

接口的返回值中只是返回了部分?jǐn)?shù)據(jù),到底是出了什么問題呢?之后我曾仔細(xì)的核對完每一個結(jié)構(gòu)字段和數(shù)據(jù)庫中字段的類型,確保并不是這些原因?qū)е碌模肓撕芫貌恢肋@個問題到底是如何發(fā)生的,無意中將結(jié)構(gòu)體中的字段名的首字母都變成了大寫,經(jīng)過編譯運(yùn)行之后終于拿到了全部的數(shù)據(jù),

有了這個結(jié)果之后,我又去仔細(xì)的google了一下這個問題,原來結(jié)構(gòu)體中的每一項(xiàng)如果是導(dǎo)出項(xiàng)的時候首字母必須是大寫的,但是問題是SQL語句中在數(shù)據(jù)庫中存入的信息都是首字母小寫的,檢索出來的結(jié)果卻是大寫的,很明顯這個處理過程中大小寫匹配的問題被忽略掉了,因此要想按照我們的信息隨意匹配的話就得在結(jié)構(gòu)體后面加tag,這樣解析時就會只匹配tag中的名字,但是tag中的結(jié)果不能為空格否則依舊會報錯。

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • golang中json小談之字符串轉(zhuǎn)浮點(diǎn)數(shù)的操作
  • golang 實(shí)現(xiàn)json類型不確定時的轉(zhuǎn)換
  • golang中json的omitempty使用操作
  • golang:json 反序列化的[]和nil操作
  • 解決Golang json序列化字符串時多了\的情況
  • golang xorm及time.Time自定義解決json日期格式的問題
  • golang 實(shí)現(xiàn)struct、json、map互相轉(zhuǎn)化
  • 在golang xorm中使用postgresql的json,array類型的操作

標(biāo)簽:儋州 電子產(chǎn)品 海南 安康 物業(yè)服務(wù) 西雙版納 遼寧 青海

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《解決golang json解析出現(xiàn)值為空的問題》,本文關(guān)鍵詞  解決,golang,json,解,析出,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《解決golang json解析出現(xiàn)值為空的問題》相關(guān)的同類信息!
  • 本頁收集關(guān)于解決golang json解析出現(xiàn)值為空的問題的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲一区视频在线观看视频| 欧美无砖砖区免费| 国产福利一区二区三区| 在线国产电影不卡| 久久久久久**毛片大全| 亚洲国产中文字幕在线视频综合| 视频一区二区三区在线| 日韩国产精品久久久| 91国内精品野花午夜精品| 精品久久久久久久久久久院品网 | 精品国产sm最大网站免费看| 亚洲美女一区二区三区| 亚洲精品成人天堂一二三| 夜夜嗨av一区二区三区| 亚洲成人免费av| 精品一二线国产| 国产一区二区在线视频| 成人午夜激情视频| 色天使久久综合网天天| 日韩三级精品电影久久久| 日本一区二区三区久久久久久久久不| 亚洲国产精品99久久久久久久久| 樱花草国产18久久久久| 精品一区在线看| 在线观看国产精品网站| 欧美精品一区二区三| 国产毛片一区二区| 精品视频1区2区3区| 国产色91在线| 日韩av在线播放中文字幕| 国产精品综合网| 久久嫩草精品久久久精品一| 99久久精品国产精品久久| 天天综合色天天综合色h| 欧美精品一区二区三区蜜臀| 99久久精品情趣| 欧美一区二区三区视频| 精品一区二区三区免费毛片爱 | 久久久精品人体av艺术| 色婷婷久久久久swag精品 | 黄色日韩三级电影| 亚洲欧美在线aaa| 26uuu亚洲| 欧美三级电影一区| 成人免费看的视频| 五月婷婷另类国产| 亚洲日本在线看| 久久久噜噜噜久噜久久综合| 3atv一区二区三区| 精品一区二区三区免费毛片爱 | 九九**精品视频免费播放| 国产精品传媒在线| 欧美日韩高清一区二区三区| 99国产精品国产精品久久| 玖玖九九国产精品| 亚洲电影在线免费观看| 国产精品久久久久久久第一福利| 久久久久国产精品厨房| 欧美日韩和欧美的一区二区| 色爱区综合激月婷婷| 国产主播一区二区三区| 日韩激情视频在线观看| 亚洲欧美一区二区三区国产精品| 26uuu国产一区二区三区| 亚洲精品亚洲人成人网在线播放| 欧美激情一区二区三区| 欧美一区二区三区免费在线看 | 99精品视频免费在线观看| 国产成人福利片| 国产伦精品一区二区三区免费| 欧美aⅴ一区二区三区视频| 秋霞国产午夜精品免费视频| 免费一级欧美片在线观看| 日韩1区2区日韩1区2区| 热久久久久久久| 国内成人免费视频| av电影一区二区| 欧美视频在线一区二区三区| 精品美女被调教视频大全网站| 国产欧美日韩综合精品一区二区| 中文字幕一区二区视频| 日韩一区二区三区精品视频| 日本道在线观看一区二区| 成人午夜视频福利| 国产精品伊人色| 另类小说欧美激情| 国产99久久久精品| 国产一区二区三区四区五区美女| 美女视频黄a大片欧美| 日韩av网站在线观看| 婷婷开心久久网| 五月天国产精品| 午夜欧美大尺度福利影院在线看| 亚洲免费在线视频| 亚洲欧美另类小说视频| 亚洲日本va午夜在线影院| 中文字幕一区不卡| 一区二区在线看| 婷婷六月综合亚洲| 欧美性xxxxxxxx| 亚洲色图另类专区| 成人精品视频.| 久久久久久久久一| 精品一区二区在线看| 91电影在线观看| 亚洲婷婷在线视频| 懂色av噜噜一区二区三区av| 欧美精品一区二区三区蜜桃| 亚洲二区在线观看| 欧美一a一片一级一片| 夜夜嗨av一区二区三区四季av| 激情欧美一区二区三区在线观看| 成人视屏免费看| 欧美日韩亚洲丝袜制服| 欧美成人精品3d动漫h| 综合电影一区二区三区 | 成人av网址在线| 欧美三片在线视频观看| 久久综合色一综合色88| 亚洲一区二区三区自拍| 精品中文字幕一区二区小辣椒| 韩国女主播一区| 51午夜精品国产| 国产精品欧美经典| 日本麻豆一区二区三区视频| 91丨porny丨国产入口| 久久综合久久久久88| 亚洲成av人片在线| 色婷婷av一区二区三区大白胸| 日韩精品中文字幕在线一区| 自拍偷拍亚洲激情| 豆国产96在线|亚洲| www欧美成人18+| 狂野欧美性猛交blacked| 欧美日韩视频一区二区| 亚洲视频 欧洲视频| 国产一区二区三区在线观看精品| 91麻豆免费视频| 久久精品久久99精品久久| 国产精品久久久久久久第一福利| 欧美日韩一区二区在线观看| 国产精品亚洲专一区二区三区 | 日韩av电影免费观看高清完整版在线观看| 99麻豆久久久国产精品免费| 亚洲一区欧美一区| 成人精品高清在线| 国产精品高潮呻吟| 国产成人在线视频网站| 久久精品亚洲精品国产欧美kt∨ | 欧美国产视频在线| 成人精品视频一区| 亚洲欧洲在线观看av| 国产成人精品午夜视频免费| 日韩一区中文字幕| 91久久精品一区二区三| 亚洲一区视频在线| 欧美一级淫片007| 综合色中文字幕| 欧美日韩国产小视频| 日本不卡视频一二三区| 国产欧美日韩亚州综合| 91精品福利视频| 韩国一区二区在线观看| 久久久久久久电影| 91免费视频观看| 免费黄网站欧美| 国产精品国产精品国产专区不蜜| 在线观看视频91| 国产一区福利在线| 一区二区视频在线看| 欧美一级在线视频| 欧洲精品在线观看| 国产成人精品免费一区二区| 天天影视网天天综合色在线播放| 久久精品一级爱片| 69堂亚洲精品首页| 国产.精品.日韩.另类.中文.在线.播放| 国产精品久久综合| 欧美va在线播放| 欧美三区在线观看| 91视频免费播放| 国产一区二区精品久久91| 免费人成黄页网站在线一区二区| 一级中文字幕一区二区| 亚洲欧美偷拍三级| 国产精品动漫网站| 国产精品灌醉下药二区| 国产精品免费视频网站| 国产精品电影一区二区| 国产电影一区二区三区| 久久国产三级精品| 免费看欧美美女黄的网站| 五月天亚洲精品| 日产国产高清一区二区三区| 日av在线不卡| 韩国成人福利片在线播放| 久久精品国产99国产| 蜜臀国产一区二区三区在线播放 | 看国产成人h片视频| 亚洲444eee在线观看|