当服务端对http的body进行解析到map[string]interface{}时,会出现cli传递的是int类型,而服务端只能断言成float64,而不能将接收到的本该是int类型的直接断言为int
cli
func main(){ url:="http://127.0.0.1:8335/api/v2/submit" myReq:= struct { ProductId int `json:"product_id"` Mobile string `json:"mobile"` Content string `json:"content"` Grade float64 `form:"grade" json:"grade"` Image string `form:"image" json:"image"` Longitude float64 `json:"longitude"` Latitude float64 `json:"latitude"` }{ ProductId:219, Mobile:"15911111111", Content: "这个软件LOGO真丑", Image: "www.picture.com;www.picture.com", Longitude: 106.3037109375, Latitude: 38.5137882595, Grade:9.9, } reqByte,err:=json.Marshal(myReq) req, err := http.NewRequest("POST", url, bytes.NewReader(reqByte)) if err != nil { return } //设置请求头 req.Header.Add("Content-Type", "application/json") cli := http.Client{ Timeout: 45 * time.Second, } resp, err := cli.Do(req) if err != nil { return } out, err := ioutil.ReadAll(resp.Body) if err != nil { return } fmt.Println(string(out)) }
server
func SubmitV2(c *gin.Context) { resp := &dto.Response{} obj:=make(map[string]interface{}) var buf []byte var err error buf, err =ioutil.ReadAll(c. Request.Body) if err!=nil { return } err=json.Unmarshal(buf,&obj) if err!=nil { return } fmt.Println("product_id:",reflect.TypeOf(obj["product_id"])) fmt.Println("image:",reflect.TypeOf(obj["image"])) fmt.Println(obj) productId:=obj["product_id"].(float64) //注意,这里断言成int类型会出错 c.Request.Body = ioutil.NopCloser(bytes.NewBuffer(buf)) if !checkProduct(int(productId)){ resp.Code = -1 resp.Message = "xxxxxx" c.JSON(http.StatusOK, resp) return } url := config.Optional.OpinionHost + "/api/v1/submit" err = http_utils.PostAndUnmarshal(url, c.Request.Body, nil, resp) if err != nil { logrus.WithError(err).Errorln("Submit: error") resp.Code = -1 resp.Message = "Submit" } c.JSON(http.StatusOK, resp) }
打印类型,发现product_id是float64类型
原因:json中的数字类型没有对应int,解析出来都是float64
补充:Golang Web 获取 http 请求报文主体 body 的内容
示例代码:
package main import ( "fmt" "net/http" ) func headerBody(rw http.ResponseWriter, r *http.Request) { // 获取请求报文的内容长度 len := r.ContentLength // 新建一个字节切片,长度与请求报文的内容长度相同 body := make([]byte, len) // 读取 r 的请求主体,并将具体内容读入 body 中 r.Body.Read(body) // 将字节切片内容写入相应报文 fmt.Fprintln(rw, body) } func main() { server := http.Server{ Addr: "127.0.0.1:http", } http.HandleFunc("/", headerBody) server.ListenAndServe() }
注意:
1. get 请求不包含报文主体。
2. post 请求不包含报文主体。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。