Я попытался работать с Apiary и сделал универсальный шаблон для отправки JSON на макет сервера и получить этот код:
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())
}
Этот код не отправляет JSON должным образом, но я не знаю почему. Строка JSON может отличаться при каждом вызове. Я не могу использовать Struct
для этого.
json.Marshall
к ней, я не уверен, почему это не работает для него.Ответы:
Я не знаком с врасплох, но использование
net/http
пакета Голанга прекрасно работает ( детская площадка ):источник
client.Timeout = time.Second * 15
Вы можете просто использовать,
post
чтобы опубликовать свой JSON.источник
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
дляhttp.Post
и bytes.NewBuffer () хорошо работает в моем кодеbytes.NewBuffer()
но используетhttp.NewRequest
вместоhttp.Post
)resp.Body
когда завершит чтение из него. Если предоставленное тело являетсяio.Closer
, оно закрывается после запроса». Как я могу сказать, как новичок Go, если тело являетсяio.Closer
, или другими словами, если этот пример безопасен?Если у вас уже есть структура.
Полная суть .
источник
В дополнение к стандартному пакету net / http, вы можете рассмотреть возможность использования моего GoRequest который охватывает net / http и упрощает вашу жизнь, не слишком задумываясь о json или struct. Но вы также можете смешивать и сочетать их в одном запросе! (Вы можете увидеть более подробную информацию об этом на странице Gorequest GitHub)
Итак, в конце ваш код станет следующим:
Это зависит от того, как вы хотите достичь. Я создал эту библиотеку, потому что у меня та же проблема с вами, и я хочу, чтобы код был более коротким, простым в использовании с JSON и более удобным в моей кодовой базе и рабочей системе.
источник
tr := &http.Transport{ TLSClientConfig: &tls.Config{InsecureSkipVerify: true}, }