使用Go語言寫一個Http?Server的實現(xiàn)
Http Server 代碼
go.mod:
module goStudy1 go 1.17
main.go:
package main import ( "fmt" "os" "strconv" //"github.com/thinkeridea/go-extend/exnet" "io" "log" "net/http" "strings" ) /* 編寫一個 HTTP 服務器,4個功能: 1,接收客戶端 request,并將 request 中帶的 header 寫入 response header 2,讀取當前系統(tǒng)的環(huán)境變量中的 VERSION 配置,并寫入 response header 3,Server 端記錄訪問日志包括客戶端 IP,HTTP 返回碼,輸出到 server 端的標準輸出 4,當訪問 localhost/healthz 時,應返回 200 */ // Main方法入口 func main() { println("環(huán)境正常") // 功能1 http.HandleFunc("/requestAndResponse", requestAndResponse) // 功能2 http.HandleFunc("/getVersion", getVersion) // 功能3 http.HandleFunc("/ipAndStatus", ipAndStatus) //注冊接口句柄 // 功能4 http.HandleFunc("/healthz", healthz) //注冊接口句柄 err := http.ListenAndServe(":81", nil) //監(jiān)聽空句柄,80端口被占用,使用81端口 if nil != err { log.Fatal(err) //顯示錯誤日志 } } // 功能1,接收請求及響應 func requestAndResponse(response http.ResponseWriter, request *http.Request) { println("調用requestAndResponse接口") headers := request.Header //header是Map類型的數(shù)據(jù) println("傳入的hander:") for header := range headers { //value是[]string //println("header的key:" + header) values := headers[header] for index, _ := range values { values[index] = strings.TrimSpace(values[index]) //println("index=" + strconv.Itoa(index)) //println("header的value:" + values[index]) } //valueString := strings.Join(values, "") //println("header的value:" + valueString) println(header + "=" + strings.Join(values, ",")) //打印request的header的k=v response.Header().Set(header, strings.Join(values, ",")) // 遍歷寫入response的Header //println() } fmt.Fprintln(response, "Header全部數(shù)據(jù):", headers) io.WriteString(response, "succeed") } // 功能2,獲取環(huán)境變量的version func getVersion(response http.ResponseWriter, request *http.Request) { println("調用getVersion接口") envStr := os.Getenv("VERSION") //envStr := os.Getenv("HADOOP_HOME") //println("系統(tǒng)環(huán)境變量:" + envStr) //可以看到 C:\soft\hadoop-3.3.1 Win10需要重啟電腦才能生效 response.Header().Set("VERSION", envStr) io.WriteString(response, "succeed") } // 功能3,輸出IP與返回碼 func ipAndStatus(response http.ResponseWriter, request *http.Request) { println("調用ipAndStatus接口") form := request.RemoteAddr println("Client->ip:port=" + form) //虛擬機是橋接模式。使用postman返回的全部是127.0.0.1 用手機打開網(wǎng)站192.168.1.139:81/ipAndStatus可以看到新IP ipStr := strings.Split(form, ":") println("Client->ip=" + ipStr[0]) //打印ip // 獲取http響應碼 //response.WriteHeader(301) //手動設置響應碼,默認200 //response.WriteHeader(http.StatusOK)//由于默認是調用這個,∴返回碼都是這個200【server.go有源碼】 println("Client->response code=" + strconv.Itoa(http.StatusOK)) //println("response code->:" + code) io.WriteString(response, "succeed") } // 功能4,連通性測試接口 func healthz(response http.ResponseWriter, request *http.Request) { println("調用healthz接口") response.WriteHeader(200) //設置返回碼200 //response.WriteHeader(http.StatusOK)//默認會調用這個方法,默認就是200【server.go有源碼】 io.WriteString(response, "succeed") }
由于80端口被占用,使用了81端口。
調試
由于Linux虛擬機沒有安裝go環(huán)境,只有windows有go環(huán)境,使用goland開發(fā)后,用postman調試。
功能1
網(wǎng)站:http://127.0.0.1:81/requestAndResponse
POST的request中額外配置了 k2=v1 。Send后可以看到:
Response中出現(xiàn)了手動新增的請求頭及其它默認的請求頭?!驹嫉膔esponse只有3對kv結果,已經(jīng)遍歷添加成功】。說明成功寫入。
功能2
由于Windows需要重啟才能刷新環(huán)境變量,故:
//envStr := os.Getenv("VERSION") envStr := os.Getenv("HADOOP_HOME")
測試時,此處讀取已經(jīng)存在的環(huán)境變量,原理是一致的。
網(wǎng)站:http://127.0.0.1:81/getVersion
說明Go可以讀取到環(huán)境變量的值,并且寫入response的headers。
功能3
網(wǎng)站:http://127.0.0.1:81/ipAndStatus
分別用postman、手機請求這個網(wǎng)站【手機請求時需要和PC在同一個路由,將網(wǎng)站IP更換為PC的IP才可以訪問】,goland中顯示:
環(huán)境正常 調用getVersion接口 調用ipAndStatus接口 Client->ip:port=127.0.0.1:59595 Client->ip=127.0.0.1 Client->response code=200 調用ipAndStatus接口 Client->ip:port=192.168.1.138:37548 Client->ip=192.168.1.138 Client->response code=200
顯然讀取到了client的IP。由于server.go中有寫:
// WriteHeader sends an HTTP response header with the provided // status code. // // If WriteHeader is not called explicitly, the first call to Write // will trigger an implicit WriteHeader(http.StatusOK). // Thus explicit calls to WriteHeader are mainly used to // send error codes. // // The provided code must be a valid HTTP 1xx-5xx status code. // Only one header may be written. Go does not currently // support sending user-defined 1xx informational headers, // with the exception of 100-continue response header that the // Server sends automatically when the Request.Body is read. WriteHeader(statusCode int)
默認的響應頭就是取返回值為200,不設置就是按照默認的200來返回,故此處的響應碼為200。
由于響應體引用的請求體并不包含返回碼,如果直接從響應體的請求中拿返回碼【request.Response.StatusCode】,會報內(nèi)存錯誤及空指針的panic。
功能4
網(wǎng)址:http://127.0.0.1:81/healthz
使用postman調用接口,可以看到:
默認的響應體的響應頭的返回碼就是200。且返回值3個。
可以看出,Go相比Java還是很簡潔的。
到此這篇關于使用Go語言寫一個Http Server的實現(xiàn)的文章就介紹到這了,更多相關Go語言Http Server內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Gin與Mysql實現(xiàn)簡單Restful風格API實戰(zhàn)示例詳解
這篇文章主要為大家介紹了Gin與Mysql實現(xiàn)簡單Restful風格API示例詳解,有需要的朋友可以借鑒參考下希望能夠有所幫助,祝大家多多進步2021-11-11詳解golang 定時任務time.Sleep和time.Tick實現(xiàn)結果比較
本文主要介紹了golang 定時任務time.Sleep和time.Tick實現(xiàn)結果比較,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02Go語言fsnotify接口實現(xiàn)監(jiān)測文件修改
這篇文章主要為大家介紹了Go語言fsnotify接口實現(xiàn)監(jiān)測文件修改的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06Go語言實現(xiàn)字符串搜索算法Boyer-Moore
Boyer-Moore?算法是一種非常高效的字符串搜索算法,被廣泛的應用于多種字符串搜索場景,下面我們就來學習一下如何利用Go語言實現(xiàn)這一字符串搜索算法吧2023-11-11Golang編程實現(xiàn)生成n個從a到b不重復隨機數(shù)的方法
這篇文章主要介紹了Golang編程實現(xiàn)生成n個從a到b不重復隨機數(shù)的方法,結合實例形式分析了Go語言字符串操作及隨機數(shù)生成的相關操作技巧,需要的朋友可以參考下2017-01-01