Go http源码解析(一)

Go web之旅

此篇开始将开启Go web之旅,我将这趟旅途分为三个子旅程:

  1. 源码解析
  2. 框架解读
  3. 中间件使用

所以在这趟旅途中我们将领略源码之雄伟,框架之奇艳,中间件之灵秀。在接下来的时间里我会按照上面的目录依次讲解。
现在开始踏上Go web的旅程。

func firstHandler(w http.ResponseWriter, r *http.Request) {
     io.WriteString(w, "Hello,world")
}
func main() {
        http.HandleFunc("/hello", firstHandler)
    http.ListenAndServe(":8080", nil)
}

在main函数中,http.HandleFunc设置所有对路径为/hello请求的处理函数为firstHandler.
接下来调用http.ListenAndServe,在8080端口开始监听将阻塞,直到退出。

我们将以源码解析作为整个旅程的开篇。
Go语言作为互联网中的c语言,他让web开发简洁到不能再简洁了。首先我们来介绍他让web开发变得简易所涉及的最重要的包(package)(当遇到包时一般直接用package表示)之一http.

package http在service.go中。
// HTTP server.  See RFC 2616.
package http
//声明一个Handler接口,若某函数实现了ServeHTTP函数就实现了该接口
type Handler interface {
    ServeHTTP(ResponseWriter, *Request)
}

那我们该如何实现该接口呢?
其实在service.go中他已经默认实现了该函数

type ServeMux struct {//定义路由规则
     mu    sync.RWMutex//锁机制,因为并发处理需要一个锁
     m     map[string]muxEntry//路由,采用map结构
    hosts bool // whether any patterns contain hostnames
}
type muxEntry struct {//路由
     explicit bool   //是否精准匹配
     h        Handler//路由匹配后,所选择的处理
    pattern  string //匹配字符串
}

// ServeHTTP dispatches the request to the handler whose
// pattern most closely matches the request URL.
//路由结构ServeMux实现ServeHTTP函数
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)
}

从godoc提示可以知道,当一个请求来时,先进行路由匹配,这一过程由ServeMux.m中的string来匹配完成。
匹配成功后选择muxEntry.h所对应的handler进行处理,而这一步是调用ServeHTTP实现。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

脑机接口社区

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值