我就廢話(huà)不多說(shuō)了,大家還是直接看代碼吧~
代碼如下
type KDRespBody struct {
Errcode int `json:"errcode"`
Desc string `json:"description"`
Data []services.KdSearchBack `json:"data"`
}
var reqInfo KDRespBody
err := c.BindJSON(reqInfo)
if err != nil {
log.Info(err)
c.JSON(200, gin.H{"errcode": 400, "description": "Post Data Err"})
return
} else {
fmt.Println(reqInfo.Data)
}
補(bǔ)充:使用gin接受post的json數(shù)據(jù)
第一種
func Login(c *gin.Context) {
json := make(map[string]interface{}) //注意該結(jié)構(gòu)接受的內(nèi)容
c.BindJSON(json)
log.Printf("%v",json)
c.JSON(http.StatusOK, gin.H{
"name": json["name"],
"password": json["password"],
})
}
第二種
type User struct {
Name string `json:"name"`
Password int64 `json:"password"`
}
func Login(c *gin.Context) {
json := User{}
c.BindJSON(json)
log.Printf("%v",json)
c.JSON(http.StatusOK, gin.H{
"name": json.Name,
"password": json.Password,
})
}
補(bǔ)充:golang json數(shù)據(jù)解析錯(cuò)誤情況
byte數(shù)組接收網(wǎng)絡(luò)數(shù)據(jù)完網(wǎng)絡(luò)數(shù)據(jù)后,需要根據(jù)接收到的長(zhǎng)度進(jìn)行重新分片,才能被json進(jìn)行解析,不然會(huì)報(bào)錯(cuò)。
for {
len1, err := resp.Body.Read(data)
if len1 > 0 {
data1 := data[:len1] //需要根據(jù)接收到的長(zhǎng)度進(jìn)行重新分片
err1 := json.Unmarshal(data1, rec_rep)
if err1 != nil {
fmt.Println("json.Unmarshal failed")
}
}
if err != nil {
break
}
}
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- js實(shí)現(xiàn)axios限制請(qǐng)求隊(duì)列
- JavaScript如何利用Promise控制并發(fā)請(qǐng)求個(gè)數(shù)
- 利用js實(shí)現(xiàn)Ajax并發(fā)請(qǐng)求限制請(qǐng)求數(shù)量的示例代碼
- JS 實(shí)現(xiàn)請(qǐng)求調(diào)度器
- PHP實(shí)現(xiàn)chrome表單請(qǐng)求數(shù)據(jù)轉(zhuǎn)換為接口使用的json數(shù)據(jù)
- JavaScript 中斷請(qǐng)求幾種方案詳解