我试图在其中发布带有xml消息的json.然而它又回来了
无效字符'b'寻找值的开头
我认为可能的原因是我试图编组不是json格式的返回体.
func (s *BackendConfiguration) Do(req *http.Request, v interface{}) error {
log.Printf("Requesting %v %v%v\n", req.Method, req.URL.Host, req.URL.Path)
start := time.Now()
res, err := s.HTTPClient.Do(req)
if debug {
log.Printf("Completed in %v\n", time.Since(start))
}
if err != nil {
log.Printf("Request to sakura failed: %v\n", err)
return err
}
defer res.Body.Close()
resBody, err := ioutil.ReadAll(res.Body)
if err != nil {
log.Printf("Cannot parse sakura response: %v\n", err)
return err
}
if debug {
log.Printf("sakura response: %q\n", resBody)
}
if v != nil {
return json.Unmarshal(resBody, v)
}
return nil
}
Run Code Online (Sandbox Code Playgroud)
错误发生在这一行
return json.Unmarshal(resBody, v)
Run Code Online (Sandbox Code Playgroud)
Cer*_*món 14
该错误表示服务器未返回有效的JSON响应.我建议添加以下代码来调试问题:
err := json.Unmarshal(resBody, v)
if err != nil {
log.Printf("error decoding sakura response: %v", err)
if e, ok := err.(*json.SyntaxError); ok {
log.Printf("syntax error at byte offset %d", e.Offset)
}
log.Printf("sakura response: %q", resBody)
return err
}
Run Code Online (Sandbox Code Playgroud)