В большинстве случаев вам нужно просто использовать json.Unmarshal. Этот вариант использования работает большую часть времени:
var myClient = &http.Client{Timeout: 10 * time.Second}
func getJson(url string, target interface{}) error {
r, err := myClient.Get(url)
if err != nil {
return err
}
defer r.Body.Close()
return json.NewDecoder(r.Body).Decode(target)
}
foo := Foo{}
getJson("http://example.com", &foo2)
fmt.Printf("%+v\n", foo)
Однако, если вы действительно работаете с большим набором данных, посмотрите https://golang.org/pkg/encoding/json/#example_Decoder_Decode_stream
package main
import (
"encoding/json"
"fmt"
"log"
"strings"
)
func main() {
const jsonStream = `
[
{"Name": "Ed", "Text": "Knock knock."},
{"Name": "Sam", "Text": "Who's there?"},
{"Name": "Ed", "Text": "Go fmt."},
{"Name": "Sam", "Text": "Go fmt who?"},
{"Name": "Ed", "Text": "Go fmt yourself!"}
]
`
type Message struct {
Name, Text string
}
dec := json.NewDecoder(strings.NewReader(jsonStream))
// read open bracket
t, err := dec.Token()
if err != nil {
log.Fatal(err)
}
fmt.Printf("%T: %v\n", t, t)
// while the array contains values
for dec.More() {
var m Message
// decode an array value (Message)
err := dec.Decode(&m)
if err != nil {
log.Fatal(err)
}
fmt.Printf("%v: %v\n", m.Name, m.Text)
}
// read closing bracket
t, err = dec.Token()
if err != nil {
log.Fatal(err)
}
fmt.Printf("%T: %v\n", t, t)
}
Это позволит вам работать более эффективно с памятью.
К большему количеству вопросов:
- Должен ли я разархивировать структуру полного ответа? - Не совсем, вам нужно только определить, что вы хотите использовать в структуре, остальные будут игнорироваться
- Вы делаете это правильно? - Вы не делаете ничего по своей сути неправильно?
Если я что-то не ответил, пожалуйста, дайте мне знать.
Редактировать: Для вашего использования ioutil.ReadAll
- Вообще говоря, вы захотите разархивировать структуру, чтобы вы могли использовать данных и пользоваться безопасностью типов через ваши структуры. Если вам буквально нужна строка, то то, что вы делаете, хорошо, но обычно это не так.