我正在尝试使用以下代码解析JSON响应:
type Token struct {
access_token string `json:access_token`
token_type string `json:token_type`
expires_in int `json:expires_in`
}
homeURL := "https:/blah.com/oauth2/token"
v := url.Values{}
v.Set("client_id", "xxx")
v.Set("client_secret", "xxx")
v.Set("grant_type", "xxx")
s := v.Encode()
req, err := http.NewRequest("POST", homeURL, strings.NewReader(s))
if err != nil {
fmt.Printf("http.NewRequest() error: %v\n", err)
return
}
req.Header.Add("Content-Type", "application/x-www-form-urlencoded")
var client = http.Client{}
resp, err := client.Do(req)
if err != nil {
//error
fmt.Printf("http.Do() error: %v\n", err)
return
}
defer resp.Body.Close()
if resp.StatusCode == 200 {
var token Token
data, err := ioutil.ReadAll(resp.Body)
if err != nil {
fmt.Println("Error parsing JSON\n")
}
errj := json.Unmarshal(data, &token)
if errj != nil {
fmt.Println("JSON PARSING ERROR")
}
fmt.Printf("read resp.Body successfully:\n%v\n", string(data))
fmt.Printf("Response Headers \n%v\n", resp.Header)
fmt.Println(token.access_token)
} else {
fmt.Println("Request failed !" , resp.StatusCode)
}
我也尝试使用
json.NewDecoder(resp.Body).Decode(&token)
但是我无法填充令牌结构并且没有错误。我回来的反应看起来不错
成功阅读resp.Body:
{"access_token":"Osq","token_type":"Bearer","expires_in":"1247"}
Response Headers
map[Content-Length:[384] Connection:[keep-alive] Content-Language:[en-US] Date:[Tue, 08 Aug 2017 16:52:19 GMT] Gi-Coordination-Id:[auto_--YfYqIVya0KiAv_mLLET8g] Server:[Mashery Proxy] X-Powered-By:[ASP.NET ARR/3.0 ASP.NET] Content-Type:[application/json; charset=utf-8] Pragma:[no-cache] Cache-Control:[no-cache,no-cache] Expires:[-1]]
有没有人对我用这两种方法做错了什么有任何想法?
编辑 - 解决方案:
type Token struct {
Access_token string `json:access_token`
Token_type string `json:token_type`
Expires_in int `json:expires_in`
}
Unmarshal需要导出的密钥需要大写。
答案 0 :(得分:3)
Token
中有未导出的字段(以小写字母开头的字段)。由于这些字段未导出,json
无法看到它们,因此无法解组。请阅读the documentation for json.Unmarshal
:
要将JSON解组为结构,Unmarshal匹配传入的对象 Marshal使用的键的键(结构字段名称或其字符串) 标签),更喜欢完全匹配,但也接受不区分大小写 比赛。 Unmarshal只会设置结构的导出字段。