Próbowałem pracować z pasieką i stworzyłem uniwersalny szablon, aby wysłać JSON na próbny serwer i mieć ten kod:
package main
import (
"encoding/json"
"fmt"
"github.com/jmcvetta/napping"
"log"
"net/http"
)
func main() {
url := "http://restapi3.apiary.io/notes"
fmt.Println("URL:>", url)
s := napping.Session{}
h := &http.Header{}
h.Set("X-Custom-Header", "myvalue")
s.Header = h
var jsonStr = []byte(`
{
"title": "Buy cheese and bread for breakfast."
}`)
var data map[string]json.RawMessage
err := json.Unmarshal(jsonStr, &data)
if err != nil {
fmt.Println(err)
}
resp, err := s.Post(url, &data, nil, nil)
if err != nil {
log.Fatal(err)
}
fmt.Println("response Status:", resp.Status())
fmt.Println("response Headers:", resp.HttpResponse().Header)
fmt.Println("response Body:", resp.RawText())
}
Ten kod nie wysyła poprawnie JSON, ale nie wiem dlaczego. Ciąg JSON może być inny w każdym wywołaniu. Nie mogę tego użyć Struct
.
json.Marshall
go, nie jestem pewien, dlaczego to nie działało dla niego.Odpowiedzi:
Nie znam drzemki, ale korzystanie z
net/http
pakietu Golanga działa dobrze ( plac zabaw ):źródło
client.Timeout = time.Second * 15
możesz po prostu użyć,
post
aby opublikować swój Json.źródło
cannot use jsonValue (type []byte) as type io.Reader in argument to http.Post: []byte does not implement io.Reader (missing Read method)
io.Reader
dlahttp.Post
i bytes.NewBuffer () działa dobrze w moim kodubytes.NewBuffer()
ale używahttp.NewRequest
zamiasthttp.Post
)resp.Body
po zakończeniu czytania. Jeśli podana treść jestio.Closer
, to jest zamykana po otrzymaniu żądania”. Jak mogę stwierdzić, jako nowicjusz Go, czy ciało jestio.Closer
, lub innymi słowy, czy ten przykład jest bezpieczny?Jeśli masz już strukturę.
Pełna treść .
źródło
Oprócz standardowego pakietu net / http, możesz rozważyć użycie mojego GoRequest, który obejmuje net / http i ułatwia ci życie bez zbytniego zastanawiania się nad jsonem lub struct. Ale możesz też mieszać i dopasowywać oba z nich w jednym żądaniu! (więcej szczegółów na ten temat można znaleźć na stronie githubest w Gorequest)
Tak więc ostatecznie twój kod będzie wyglądał następująco:
To zależy od tego, jak chcesz osiągnąć. Zrobiłem tę bibliotekę, ponieważ mam ten sam problem z tobą i chcę, aby kod był krótszy, łatwy w użyciu z Jsonem i bardziej łatwy w utrzymaniu w mojej bazie kodu i systemie produkcyjnym.
źródło
tr := &http.Transport{ TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, }