亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁(yè) > 知識(shí)庫(kù) > 解決golang json解析出現(xiàn)值為空的問(wèn)題

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

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

我是通過(guò)beego框架,將請(qǐng)求過(guò)來(lái)的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的值是空的,但是傳來(lái)的json是存在Id值的,當(dāng)時(shí)一頭霧水,就不斷在日志中打印,后來(lái)定位到是數(shù)據(jù)類型存在問(wèn)題,

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

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

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

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

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

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

type ParamConfig struct {
 //標(biāo)識(shí)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ī)動(dòng)車配置
 vehicle *DataConfig
 //非機(jī)動(dòng)車配置
 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ù)庫(kù)中插入一條需要解析的數(shù)據(jù)

SQL語(yǔ)句如下所示:

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}}}]');

為了方便說(shuō)明下面在代碼中打上詳細(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)行之后如圖所示:

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

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

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

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

您可能感興趣的文章:
  • golang中json小談之字符串轉(zhuǎn)浮點(diǎn)數(shù)的操作
  • golang 實(shí)現(xiàn)json類型不確定時(shí)的轉(zhuǎn)換
  • golang中json的omitempty使用操作
  • golang:json 反序列化的[]和nil操作
  • 解決Golang json序列化字符串時(shí)多了\的情況
  • golang xorm及time.Time自定義解決json日期格式的問(wèn)題
  • 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)值為空的問(wèn)題》,本文關(guān)鍵詞  解決,golang,json,解,析出,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《解決golang json解析出現(xiàn)值為空的問(wèn)題》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于解決golang json解析出現(xiàn)值為空的問(wèn)題的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    高清一级片| 国产伦精品一区三区视频| 欧美激情一区二区三区视频| 日韩一级黄色大片| 四虎久久影院| 欧美日本免费| 九九九网站| 天堂网中文字幕| 欧美a免费| 欧美大片毛片aaa免费看| 成人免费观看的视频黄页| 中文字幕97| 亚洲天堂免费| 97视频免费在线观看| 一 级 黄 中国色 片| 免费一级片在线| 国产伦精品一区三区视频| 日韩在线观看视频黄| 日韩av片免费播放| 国产伦精品一区三区视频| 久久精品人人做人人爽97| 欧美激情一区二区三区在线播放 | 青草国产在线| 国产不卡在线观看视频| 99色视频| 亚洲精品永久一区| 久久久成人网| 色综合久久天天综合观看| 精品视频一区二区三区| 一本高清在线| 国产不卡在线观看| 99热精品一区| 免费的黄色小视频| 国产亚洲男人的天堂在线观看| 99久久精品国产免费| 久久成人亚洲| 成人免费高清视频| 国产成人欧美一区二区三区的| 国产精品自拍在线| 久草免费在线色站| 国产成人精品综合久久久| 亚洲 男人 天堂| 国产视频在线免费观看| 色综合久久天天综合观看| 国产麻豆精品hdvideoss| 国产一区二区精品尤物| 国产一区免费在线观看| 黄色免费网站在线| 午夜久久网| 韩国毛片| 日韩在线观看视频黄| 国产一区二区精品久久91| 二级片在线观看| 天天做日日干| 精品视频在线看 | 欧美大片a一级毛片视频| 成人免费一级毛片在线播放视频| 精品久久久久久免费影院| 欧美国产日韩在线| 天天做日日干| 99久久精品费精品国产一区二区| 香蕉视频一级| 欧美激情一区二区三区视频高清 | 欧美国产日韩在线| 成人影院一区二区三区| 日韩男人天堂| 人人干人人草| 亚洲www美色| 日韩一级黄色| 你懂的日韩| 美女免费精品视频在线观看| 九九精品久久| 天天做日日干| 黄色免费三级| 国产亚洲男人的天堂在线观看| 四虎影视库国产精品一区| 999精品视频在线| 欧美激情一区二区三区在线| 欧美α片无限看在线观看免费| 久久精品免视看国产成人2021| 人人干人人草| 亚欧乱色一区二区三区| 日韩综合| 日本在线不卡免费视频一区| 国产精品自拍亚洲| 久久国产精品自由自在| 青青青草视频在线观看| 国产网站在线| 99色视频| 在线观看成人网| 日本特黄特黄aaaaa大片| 麻豆系列 在线视频| 精品国产一级毛片| 国产高清视频免费| 成人高清免费| 日本伦理片网站| 韩国三级香港三级日本三级la| 美女被草网站| 国产a视频精品免费观看| 欧美激情一区二区三区视频 | 久久成人综合网| 一级片片| 精品久久久久久免费影院| 999久久66久6只有精品| 99色播| 91麻豆精品国产自产在线观看一区| 欧美激情在线精品video| 久久久久久久免费视频| 国产亚洲男人的天堂在线观看| 麻豆污视频| 欧美日本免费| 亚洲第一色在线| 欧美一级视频免费| 久久国产精品自线拍免费| 国产国语对白一级毛片| 精品在线观看一区| 久久精品大片| 91麻豆爱豆果冻天美星空| 久久福利影视| 免费一级片在线| 午夜精品国产自在现线拍| 一级毛片视频免费| 日本免费看视频| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 免费一级片在线观看| 一级毛片看真人在线视频| 91麻豆精品国产片在线观看| 精品在线视频播放| 日本特黄特色aa大片免费| 精品国产亚洲一区二区三区| 国产成+人+综合+亚洲不卡| 国产伦理精品| 精品国产一区二区三区免费 | 成人免费福利片在线观看| 精品视频在线观看一区二区三区| 欧美另类videosbestsex高清 | 国产麻豆精品免费密入口| 亚洲第一页乱| 欧美a级片免费看| 精品国产一区二区三区久久久狼| 国产网站免费观看| 精品视频一区二区三区免费| 深夜做爰性大片中文| 四虎影视久久| 国产网站免费观看| 国产亚洲免费观看| 欧美激情在线精品video| 欧美一区二区三区在线观看| 日韩专区在线播放| 国产一区国产二区国产三区| 欧美激情一区二区三区视频 | 久久精品成人一区二区三区| 99久久视频| 国产麻豆精品hdvideoss| 四虎论坛| 成人a级高清视频在线观看| 韩国三级一区| 精品久久久久久中文字幕一区| 国产91精品一区| 国产伦久视频免费观看 视频| 韩国毛片免费| 国产一区二区福利久久| 亚洲第一色在线| 成人免费网站久久久| 91麻豆精品国产自产在线| 久久久久久久免费视频| 久久99这里只有精品国产| 国产a一级| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 亚洲第一色在线| 99色视频| 999久久狠狠免费精品| 欧美日本免费| 欧美a级大片| 韩国妈妈的朋友在线播放 | 麻豆网站在线看| 青青久在线视频| 99色播| 天天做日日干| 久久99中文字幕久久| 午夜激情视频在线观看 | 免费毛片基地| 成人免费观看视频| 久久久久久久久综合影视网| 亚洲女人国产香蕉久久精品| 亚欧乱色一区二区三区| 久久国产一区二区| 天天做日日干| 欧美大片毛片aaa免费看| 久久精品欧美一区二区| 你懂的日韩| 91麻豆精品国产片在线观看| 青青久在线视频| 亚欧乱色一区二区三区| 99久久精品国产国产毛片| 国产成a人片在线观看视频| 国产视频久久久| 精品国产一区二区三区国产馆| 国产视频一区二区在线播放| 欧美爱色|