J'ai essayé de travailler avec Apiary et j'ai créé un modèle universel pour envoyer JSON au faux serveur et avoir ce code:
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())
}
Ce code n'envoie pas correctement JSON, mais je ne sais pas pourquoi. La chaîne JSON peut être différente à chaque appel. Je ne peux pas l'utiliser Struct
pour ça.
json.Marshall
, je ne sais pas pourquoi cela ne fonctionnait pas pour lui.Réponses:
Je ne suis pas familier avec la sieste, mais l'utilisation du
net/http
package de Golang fonctionne très bien ( terrain de jeu ):la source
client.Timeout = time.Second * 15
vous pouvez simplement utiliser
post
pour publier votre json.la source
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
pourhttp.Post
et bytes.NewBuffer () fonctionne bien dans mon codebytes.NewBuffer()
mais utilise à lahttp.NewRequest
place dehttp.Post
)resp.Body
lorsqu'il a fini de le lire. Si le corps fourni est unio.Closer
, il est fermé après la demande." Comment puis-je savoir, en tant que débutant Go, si le corps est unio.Closer
, ou en d'autres termes, si cet exemple est sûr?Si vous avez déjà une structure.
Essentiel plein .
la source
En plus du package standard net / http, vous pouvez envisager d'utiliser ma GoRequest qui entoure net / http et vous simplifie la vie sans trop penser à json ou struct. Mais vous pouvez également mélanger et assortir les deux en une seule demande! (vous pouvez voir plus de détails à ce sujet dans la page github de gorequest)
Donc, à la fin, votre code deviendra comme suit:
Cela dépend de la façon dont vous souhaitez y parvenir. J'ai créé cette bibliothèque parce que j'ai le même problème avec vous et je veux un code plus court, facile à utiliser avec json et plus facile à gérer dans ma base de code et mon système de production.
la source
tr := &http.Transport{ TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, }