行くの言語組み込みのnet/http
パッケージは、非常に良いですHTTPクライアントとサーバーの実装を提供します。
ネット/ HTTP紹介
行くの言語組み込みのnet/http
パッケージには、HTTPクライアントとサーバーの実装を提供します。
HTTPプロトコル
ハイパーテキスト転送プロトコル(HTTP、ハイパーテキスト転送プロトコル)伝送プロトコルのインターネットで最も広く使用されている方法で、すべてのWWW文書は、この規格に準拠しなければなりません。HTTPは元々の目的は、HTMLページを公開し、受信するための方法を提供することにある設計されました。
HTTPクライアント
基本的なHTTP / HTTPSリクエスト
、HEAD、POST PostForm機能の問題とHTTP / HTTPSリクエストを取得します。
resp, err := http.Get("http://example.com/")
...
resp, err := http.Post("http://example.com/upload", "image/jpeg", &buf)
...
resp, err := http.PostForm("http://example.com/form",
url.Values{"key": {"Value"}, "id": {"123"}})
プログラムが応答を使用した後、メインの返信をシャットダウンする必要があります。
resp, err := http.Get("http://example.com/")
if err != nil {
// handle error
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
// ...
例GET要求
使用しnet/http
、次のようにパケットは、簡単な伝送クライアント側のHTTPリクエストを記述します。
package main
import (
"fmt"
"io/ioutil"
"net/http"
)
func main() {
resp, err := http.Get("https://www.nickchen121.com/")
if err != nil {
fmt.Println("get failed, err:", err)
return
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
fmt.Println("read from resp.Body failed,err:", err)
return
}
fmt.Print(string(body))
}
上記のコードが保存され、実行可能ファイルにコンパイルされた後、あなたが実施後の端末で印刷することができnickchen121.com
、ウェブサイトのホームページの内容、当社のブラウザは、クライアントにデータを送受信するために、実際にHTTPプロトコルであり、我々は通常、実際には、Webブラウザを介してアクセスしますHTTPは、サーバサイトからデータを受信することで、ブラウザはHTML、CSSに従いますし、他のルールは、ページのレンダリングを表示されます。
パラメータを持つ例GET要求
GETについてリクエストパラメータは、内蔵の言語が行く使用する必要がnet/url
処理するために、この標準ライブラリに。
func main() {
apiUrl := "http://127.0.0.1:9090/get"
// URL param
data := url.Values{}
data.Set("name", "小王子")
data.Set("age", "18")
u, err := url.ParseRequestURI(apiUrl)
if err != nil {
fmt.Printf("parse url requestUrl failed,err:%v\n", err)
}
u.RawQuery = data.Encode() // URL encode
fmt.Println(u.String())
resp, err := http.Get(u.String())
if err != nil {
fmt.Println("post failed, err:%v\n", err)
return
}
defer resp.Body.Close()
b, err := ioutil.ReadAll(resp.Body)
if err != nil {
fmt.Println("get resp failed,err:%v\n", err)
return
}
fmt.Println(string(b))
}
HandlerFuncを対応するサーバ側は次のとおりです。
func getHandler(w http.ResponseWriter, r *http.Request) {
defer r.Body.Close()
data := r.URL.Query()
fmt.Println(data.Get("name"))
fmt.Println(data.Get("age"))
answer := `{"status": "ok"}`
w.Write([]byte(answer))
}
POSTリクエストの例
上記の使用を実証するnet/http
パケット送信GET
送信、要求の例をPOST
サンプルコード要求を:
package main
import (
"fmt"
"io/ioutil"
"net/http"
"strings"
)
// net/http post demo
func main() {
url := "http://127.0.0.1:9090/post"
// 表单数据
//contentType := "application/x-www-form-urlencoded"
//data := "name=小王子&age=18"
// json
contentType := "application/json"
data := `{"name":"小王子","age":18}`
resp, err := http.Post(url, contentType, strings.NewReader(data))
if err != nil {
fmt.Println("post failed, err:%v\n", err)
return
}
defer resp.Body.Close()
b, err := ioutil.ReadAll(resp.Body)
if err != nil {
fmt.Println("get resp failed,err:%v\n", err)
return
}
fmt.Println(string(b))
}
HandlerFuncを対応するサーバ側は次のとおりです。
func postHandler(w http.ResponseWriter, r *http.Request) {
defer r.Body.Close()
// 1. 请求类型是application/x-www-form-urlencoded时解析form数据
r.ParseForm()
fmt.Println(r.PostForm) // 打印form数据
fmt.Println(r.PostForm.Get("name"), r.PostForm.Get("age"))
// 2. 请求类型是application/json时从r.Body读取数据
b, err := ioutil.ReadAll(r.Body)
if err != nil {
fmt.Println("read request.Body failed, err:%v\n", err)
return
}
fmt.Println(string(b))
answer := `{"status": "ok"}`
w.Write([]byte(answer))
}
カスタムクライアント
クライアントのHTTPヘッダフィールド、リダイレクトポリシーおよびその他の設定を管理するには、クライアントを作成します。
client := &http.Client{
CheckRedirect: redirectPolicyFunc,
}
resp, err := client.Get("http://example.com")
// ...
req, err := http.NewRequest("GET", "http://example.com", nil)
// ...
req.Header.Add("If-None-Match", `W/"wyzzy"`)
resp, err := client.Do(req)
// ...
カスタムトランスポート
プロキシ、TLSの設定、キープアライブ、圧縮およびその他の設定を管理するには、交通を作成します。
tr := &http.Transport{
TLSClientConfig: &tls.Config{RootCAs: pool},
DisableCompression: true,
}
client := &http.Client{Transport: tr}
resp, err := client.Get("https://example.com")
クライアントとトランスポートの種類は安全に離れて行く複数で同時に使用することができます。効率上の理由から、私たちはまず可能な限り再利用するなど、確立すべきです。
サーバー
デフォルトサーバー
指定されたListenAndServeは、アドレスを聞いて、プロセッサは、HTTPサーバを起動します。パラメータプロセッサは通常のプロセッサDefaultServeMux変数としてパッケージの使用を意味し、nilです。
ハンドルとHandleFunc機能は、プロセッサDefaultServeMuxに添加してもよいです。
http.Handle("/foo", fooHandler)
http.HandleFunc("/bar", func(w http.ResponseWriter, r *http.Request) {
fmt.Fprintf(w, "Hello, %q", html.EscapeString(r.URL.Path))
})
log.Fatal(http.ListenAndServe(":8080", nil))
デフォルトサーバの例
言語使用進みnet/http
、受信側サーバーのHTTPリクエストの簡単な例書くためにパッケージをnet/http
パケットがさらにネットにパケットをカプセル化され、データがHTTPプロトコルの処理専用します。具体的なコードは次のよう:
// http server
func sayHello(w http.ResponseWriter, r *http.Request) {
fmt.Fprintln(w, "Hello 沙河!")
}
func main() {
http.HandleFunc("/", sayHello)
err := http.ListenAndServe(":9090", nil)
if err != nil {
fmt.Printf("http server failed, err:%v\n", err)
return
}
}
上記のコードの実装がコンパイルされた後、アドレスバーにコンピュータ上でブラウザを開き、127.0.0.1:9090
この時点で、あなたは以下のページを参照してくださいすることができ、入力します。
カスタムサーバー
サーバの動作を管理するには、カスタムサーバーを作成することができます。
s := &http.Server{
Addr: ":8080",
Handler: myHandler,
ReadTimeout: 10 * time.Second,
WriteTimeout: 10 * time.Second,
MaxHeaderBytes: 1 << 20,
}
log.Fatal(s.ListenAndServe())