Go語(yǔ)言單控制器和多控制器使用詳解
本文實(shí)例為大家分享了Go語(yǔ)言單控制器和多控制器使用的具體代碼,供大家參考,具體內(nèi)容如下
一. 單控制器
- 在Golang的net/http包下有ServeMux實(shí)現(xiàn)了Front設(shè)計(jì)模式的Front窗口,ServeMux負(fù)責(zé)接收請(qǐng)求并把請(qǐng)求分發(fā)給處理器(Handler)
- http.ServeMux實(shí)現(xiàn)了Handler接口
type Handler interface {
?? ?ServeHTTP(ResponseWriter, *Request)
}
type ServeMux struct {
?? ?mu ? ?sync.RWMutex
?? ?m ? ? map[string]muxEntry
?? ?hosts bool // whether any patterns contain hostnames
}
func (mux *ServeMux) ServeHTTP(w ResponseWriter, r *Request) {
?? ?if r.RequestURI == "*" {
?? ??? ?if r.ProtoAtLeast(1, 1) {
?? ??? ??? ?w.Header().Set("Connection", "close")
?? ??? ?}
?? ??? ?w.WriteHeader(StatusBadRequest)
?? ??? ?return
?? ?}
?? ?h, _ := mux.Handler(r)
?? ?h.ServeHTTP(w, r)
}自定義結(jié)構(gòu)體,實(shí)現(xiàn)Handler接口后,這個(gè)結(jié)構(gòu)體就屬于一個(gè)處理器,可以處理全部請(qǐng)求
- 無(wú)論在瀏覽器中輸入的資源地址是什么,都可以訪問(wèn)ServeHTTP
package main
import "fmt"
import "net/http"
type MyHandler struct {
}
func (mh *MyHandler) ServeHTTP(res http.ResponseWriter, req *http.Request) {
? ?fmt.Fprintln(res,"輸出內(nèi)容")
}
func main() {
? ?myhandler := MyHandler{}
? ?server := http.Server{
? ? ? Addr: ? ?"127.0.0.1:8090",
? ? ? Handler: &myhandler,
? ?}
? ?server.ListenAndServe()
}二.多控制器
在實(shí)際開(kāi)發(fā)中大部分情況是不應(yīng)該只有一個(gè)控制器的,不同的請(qǐng)求應(yīng)該交給不同的處理單元.在Golang中支持兩種多處理方式
- 多個(gè)處理器(Handler)
- 多個(gè)處理函數(shù)(HandleFunc)
使用多處理器
- 使用http.Handle把不同的URL綁定到不同的處理器
- 在瀏覽器中輸入http://localhost:8090/myhandler或http://localhost:8090/myother可以訪問(wèn)兩個(gè)處理器方法.但是其他URl會(huì)出現(xiàn)404(資源未找到)頁(yè)面
package main
import "fmt"
import "net/http"
type MyHandler struct{}
type MyOtherHandler struct{}
func (mh *MyHandler) ServeHTTP(res http.ResponseWriter, req *http.Request) {
? ?fmt.Fprintln(res, "第一個(gè)")
}
func (mh *MyOtherHandler) ServeHTTP(res http.ResponseWriter, req *http.Request) {
? ?fmt.Fprintln(res, "第二個(gè)")
}
func main() {
? ?myhandler := MyHandler{}
? ?myother := MyOtherHandler{}
? ?server := http.Server{
? ? ? Addr: "localhost:8090",
? ?}
? ?http.Handle("/myhandler", &myhandler)
? ?http.Handle("/myother", &myother)
? ?server.ListenAndServe()
}多函數(shù)方式要比多處理器方式簡(jiǎn)便.直接把資源路徑與函數(shù)綁定
package main
import "fmt"
import "net/http"
//不需要定義結(jié)構(gòu)體
//函數(shù)的參數(shù)需要按照ServeHTTP函數(shù)參數(shù)列表進(jìn)行定義
func first(res http.ResponseWriter, req *http.Request) {
? ?fmt.Fprintln(res, "第一個(gè)")
}
func second(res http.ResponseWriter, req *http.Request) {
? ?fmt.Fprintln(res, "第二個(gè)")
}
func main() {
? ?server := http.Server{
? ? ? Addr: "localhost:8090",
? ?}
? ?//注意此處使用HandleFunc函數(shù)
? ?http.HandleFunc("/first", first)
? ?http.HandleFunc("/second", second)
? ?server.ListenAndServe()
}以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Go結(jié)構(gòu)體SliceHeader及StringHeader作用詳解
這篇文章主要為大家介紹了Go結(jié)構(gòu)體SliceHeader及StringHeader作用的功能及面試官愛(ài)問(wèn)的實(shí)際意義詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
golang?recover函數(shù)使用中的一些坑解析
這篇文章主要為大家介紹了golang?recover函數(shù)使用中的一些坑解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
Go中并發(fā)控制的實(shí)現(xiàn)方式總結(jié)
在Go實(shí)際開(kāi)發(fā)中,并發(fā)安全是老生常談的事情,在并發(fā)下,goroutine之間的存在數(shù)據(jù)資源等方面的競(jìng)爭(zhēng),為了保證數(shù)據(jù)一致性、防止死鎖等問(wèn)題的出現(xiàn),在并發(fā)中需要使用一些方式來(lái)實(shí)現(xiàn)并發(fā)控制,本文給大家總結(jié)了幾種實(shí)現(xiàn)方式,需要的朋友可以參考下2023-12-12
Go語(yǔ)言用map實(shí)現(xiàn)堆棧功能的方法
這篇文章主要介紹了Go語(yǔ)言用map實(shí)現(xiàn)堆棧功能的方法,實(shí)例分析了Go語(yǔ)言使用map操作堆棧的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02
golang通過(guò)反射手動(dòng)實(shí)現(xiàn)json序列化的方法
在 Go 語(yǔ)言中,JSON 序列化和反序列化通常通過(guò)標(biāo)準(zhǔn)庫(kù) encoding/json 來(lái)實(shí)現(xiàn),本文給大家介紹golang 通過(guò)反射手動(dòng)實(shí)現(xiàn)json序列化的方法,感興趣的朋友一起看看吧2024-12-12
10個(gè)可以優(yōu)化代碼的Go語(yǔ)言技巧分享
這篇文章主要為大家詳細(xì)介紹了10個(gè)可以優(yōu)化代碼的Go語(yǔ)言技巧,從而讓我們的代碼更加優(yōu)雅,文中的示例代碼講解詳細(xì),需要的小伙伴可以參考下2024-01-01

