官术网_书友最值得收藏!

Routing in net/http

Even a simple microservice will need the capability to route requests to different handlers dependent on the requested path or method. In Go this is handled by the DefaultServeMux method which is an instance of ServerMux. Earlier in this chapter, we briefly covered that when nil is passed to the handler parameter for the ListenAndServe function then the DefaultServeMux method is used. When we call the http.HandleFunc("/helloworld", helloWorldHandler) package function we are actually just indirectly calling http.DefaultServerMux.HandleFunc(…).

The Go HTTP server does not have a specific router instead any object which implements the http.Handler interface is passed as a top level function to the Listen() function, when a request comes into the server the ServeHTTP method of this handler is called and it is responsible for performing or delegating any work. To facilitate the handling of multiple routes the HTTP package has a special object called ServerMux, which implements the http.Handler interface.

There are two functions to adding handlers to a ServerMux handler:

func HandlerFunc(pattern string, handler func(ResponseWriter, *Request)) 
func Handle(pattern string, handler Handler)

The HandleFunc function is a convenience function that creates a handler who's ServeHTTP method calls an ordinary function with the func(ResponseWriter, *Request) signature that you pass as a parameter.

The Handle function requires that you pass two parameters, the pattern that you would like to register the handler and an object that implements the Handler interface:

type Handler interface { 
ServeHTTP(ResponseWriter, *Request)
}
主站蜘蛛池模板: 清新县| 横峰县| 辰溪县| 嘉定区| 子长县| 澄江县| 岐山县| 康马县| 囊谦县| 柳州市| 濮阳县| 张家口市| 宜宾市| 宜城市| 汤阴县| 南靖县| 淳化县| 招远市| 即墨市| 化隆| 沁阳市| 裕民县| 溧水县| 宜春市| 陕西省| 法库县| 南汇区| 宣汉县| 区。| 沙湾县| 新疆| 尚义县| 慈利县| 璧山县| 兴仁县| 哈巴河县| 阿拉善左旗| 广州市| 郯城县| 淮安市| 盘山县|