Go语言标准库之net_http

Go语言标准库之net_http,第1张

概述目录一、net/http介绍1.1HTTP协议二、HTTP客户端2.1基本的HTTP/HTTPS请求2.2GET请求示例2.3带参数的GET请求示例2.4Post请求示例2.5自定义Client2.6自定义Transport三、服务端3.1默认的Server3.2默认的Server示例3.3自定义Server更新、更全的《Go从入门到放弃》的更新网

目录

一、net/http介绍1.1 http协议二、http客户端2.1 基本的http/httpS请求2.2 GET请求示例2.3 带参数的GET请求示例2.4 Post请求示例2.5 自定义ClIEnt2.6 自定义Transport三、服务端3.1 默认的Server3.2 默认的Server示例3.3 自定义Server


更新、更全的《Go从入门到放弃》的更新网站,更有python、go、人工智能教学等着你:https://www.cnblogs.com/nickchen121/p/11517502.HTML

Go语言内置的net/Http包十分的优秀,提供了http客户端和服务端的实现。

一、net/http介绍

Go语言内置的net/Http包提供了http客户端和服务端的实现。

1.1 http协议

超文本传输协议(http,HyperText Transfer Protocol)是互联网上应用最为广泛的一种网络传输协议,所有的WWW文件都必须遵守这个标准。设计http最初的目的是为了提供一种发布和接收HTML页面的方法。

二、http客户端2.1 基本的http/httpS请求

Get、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"}})

程序在使用完response后必须关闭回复的主体。

resp, err := http.Get("http://example.com/")if err != nil {	// handle error}defer resp.Body.Close()body, err := IoUtil.ReadAll(resp.Body)// ...
2.2 GET请求示例

使用net/Http包编写一个简单的发送http请求的ClIEnt端,代码如下:

package mainimport (	"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协议数据的客户端,我们平时通过浏览器访问网页其实就是从网站的服务器接收http数据,然后浏览器会按照HTML、CSS等规则将网页渲染展示出来。

2.3 带参数的GET请求示例

关于GET请求的参数需要使用Go语言内置的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))}

对应的Server端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))}
2.4 Post请求示例

上面演示了使用net/Http包发送GET请求的示例,发送POST请求的示例代码如下:

package mainimport (	"fmt"	"io/IoUtil"	"net/http"	"strings")// net/http post demofunc 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))}

对应的Server端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))}
2.5 自定义ClIEnt

要管理http客户端的头域、重定向策略和其他设置,创建一个ClIEnt:

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)// ...
2.6 自定义Transport

要管理代理、TLS配置、keep-alive、压缩和其他设置,创建一个Transport:

tr := &http.Transport{	TLSClIEntConfig:    &tls.Config{RootCAs: pool},	disableCompression: true,}clIEnt := &http.ClIEnt{Transport: tr}resp, err := clIEnt.Get("https://example.com")

ClIEnt和Transport类型都可以安全的被多个go程同时使用。出于效率考虑,应该一次建立、尽量重用。

三、服务端3.1 默认的Server

ListenAndServe使用指定的监听地址和处理器启动一个http服务端。处理器参数通常是nil,这表示采用包变量DefaultServeMux作为处理器。

Handle和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))
3.2 默认的Server示例

使用Go语言中的net/Http包来编写一个简单的接收http请求的Server端示例,net/Http包是对net包的进一步封装,专门用来处理http协议的数据。具体的代码如下:

// http serverfunc 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回车,此时就能够看到如下页面了。

3.3 自定义Server

要管理服务端的行为,可以创建一个自定义的Server:

s := &http.Server{	Addr:           ":8080",	Handler:        myHandler,	ReadTimeout:    10 * time.Second,	WriteTimeout:   10 * time.Second,	MaxheaderBytes: 1 << 20,}log.Fatal(s.ListenAndServe())
总结

以上是内存溢出为你收集整理的Go语言标准库之net_http全部内容,希望文章能够帮你解决Go语言标准库之net_http所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1238626.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存