-
Notifications
You must be signed in to change notification settings - Fork 7
/
doc.go
116 lines (115 loc) · 3.95 KB
/
doc.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
// SPDX-License-Identifier: MIT
// Package mux 是一个提供了路由匹配功能的中间件
//
// m := mux.New(false, false, false, nil, nil).
// Get("/users/1", h).
// Post("/login", h).
// Get("/posts/{id:\\d+}", h). // 正则路由
// Options("/users/1", "GET") // 手动指定 OPTIONS 请求的返回内容。
//
// // 统一前缀路径的路由
// p := m.Prefix("/api")
// p.Get("/logout", h) // 相当于 m.Get("/api/logout", h)
// p.Post("/login", h) // 相当于 m.Get("/api/login", h)
//
// // 对同一资源的不同操作
// res := p.Resource("/users/{id\\d+}")
// res.Get(h) // 相当于 m.Get("/api/users/{id}", h)
// res.Post(h) // 相当于 m.Post("/api/users/{id}", h)
// res.URL(map[string]string{"id": "5"}) // 生成 /users/5
//
// http.ListenAndServe(":8080", m)
//
//
//
// 正则表达式
//
// 路由中支持以正则表达式的方式进行匹配,表达式以大括号包含,内部以冒号分隔,
// 前半部分为变量的名称,后半部分为变量可匹配类型的正则表达式。比如:
// /posts/{id:\\d+} // 将被转换成 /posts/(?P<id>\\d+)
// /posts/{:\\d+} // 将被转换成 /posts/\\d+
//
//
//
// 命名参数
//
// 若路由字符串中,所有的正则表达式都只有名称部分(没有冒号及之后的内容),
// 则会被转换成命名参数,因为不需要作正则验证,性能会比较正则稍微好上一些。
// 命名参数匹配所有字符。
// /posts/{id}.html // 匹配 /posts/1.html
// /posts-{id}-{page}.html // 匹配 /posts-1-10.html
//
//
//
// 通配符
//
// 在路由字符串中若是以命名参数结尾的,则表示可以匹配之后的任意字符。
// /blog/assets/{path}
// /blog/{tags:\\w+}/{path}
// /blog/assets{path}
//
//
//
// 路径匹配规则
//
// 可能会出现多条记录与同一请求都匹配的情况,这种情况下,
// 系统会找到一条认为最匹配的路由来处理,判断规则如下:
// 1. 普通路由优先于正则路由;
// 2. 正则路由优先于命名路由;
//
// 比如:
// /posts/{id}.html // 1
// /posts/{id:\\d+}.html // 2
// /posts/1.html // 3
//
// /posts/1.html // 匹配 3
// /posts/11.html // 匹配 2
// /posts/index.html // 匹配 1
//
//
//
// 域名限定
//
// 如果路由以非 / 开头,则自动将第一个 / 之前的判定为域名,并对其进行域名限定。
// 域名部分不能带端口号。
// 比如以下格式:
// example.com/html/{id}.html // 匹配 example.com/html/1.html
// *.example.com/html/{id}.html // 支持泛域名,匹配 s1.example.com/html/1.html
//
//
//
// 路由参数
//
// 通过正则表达式匹配的路由,其中带命名的参数可通过 Params() 获取:
// params := Params(r)
//
// id, err := params.Int("id")
// // 或是
// id := params.MustInt("id", 0) // 0 表示在无法获取 id 参数的默认值
//
//
//
// OPTIONS
//
// 默认情况下,用户无须显示地实现它,系统会自动实现。
// 当然用户也可以使用 *.Options() 函数指定特定的数据;
// 或是直接使用 *.Handle() 指定一个自定义的实现方式。
//
// 如果不需要的话,也可以在 New() 中将 disableOptions 设置为 true。
// 显示设定 OPTIONS,不受 disableOptions 的影响。
// m := mux.New(...)
// m.Get("/posts/{id}", nil) // 默认情况下, OPTIONS 的报头为 GET, OPTIONS
// m.Options("/posts/{id}", "*") // 强制改成 *
// m.Delete("/posts/{id}", nil) // OPTIONS 依然为 *
//
// m.Remove("/posts/{id}", http.MethodOptions) // 在当前路由上禁用 OPTIONS
// m.Handle("/posts/{id}", h, http.MethodOptions) // 显示指定一个处理函数 h
//
//
//
// HEAD
//
// 默认情况下,用户无须显示地实现 HEAD 请求,
// 系统会为每一个 GET 请求自动实现一个对应的 HEAD 请求,
// 当然也与 OPTIONS 一样,你也可以自通过 mux.Handle() 自己实现 HEAD 请求。
package mux