2020-07-26 17:09:05 +08:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
|
|
|
"net/http"
|
|
|
|
|
2020-08-08 16:40:10 +08:00
|
|
|
"github.com/tal-tech/go-zero/core/logx"
|
|
|
|
"github.com/tal-tech/go-zero/core/service"
|
|
|
|
"github.com/tal-tech/go-zero/rest"
|
|
|
|
"github.com/tal-tech/go-zero/rest/httpx"
|
2020-07-26 17:09:05 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
port = flag.Int("port", 3333, "the port to listen")
|
|
|
|
timeout = flag.Int64("timeout", 0, "timeout of milliseconds")
|
|
|
|
)
|
|
|
|
|
|
|
|
type Request struct {
|
|
|
|
User string `form:"user,options=a|b"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func first(next http.HandlerFunc) http.HandlerFunc {
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
w.Header().Add("X-Middleware", "first")
|
|
|
|
next(w, r)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func second(next http.HandlerFunc) http.HandlerFunc {
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
w.Header().Add("X-Middleware", "second")
|
|
|
|
next(w, r)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func handle(w http.ResponseWriter, r *http.Request) {
|
|
|
|
var req Request
|
|
|
|
err := httpx.Parse(r, &req)
|
|
|
|
if err != nil {
|
|
|
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
httpx.OkJson(w, "helllo, "+req.User)
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
|
|
|
|
2020-07-31 11:45:16 +08:00
|
|
|
engine := rest.MustNewServer(rest.RestConf{
|
2020-07-26 17:09:05 +08:00
|
|
|
ServiceConf: service.ServiceConf{
|
|
|
|
Log: logx.LogConf{
|
|
|
|
Mode: "console",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Port: *port,
|
|
|
|
Timeout: *timeout,
|
|
|
|
MaxConns: 500,
|
|
|
|
})
|
|
|
|
defer engine.Stop()
|
|
|
|
|
|
|
|
engine.Use(first)
|
|
|
|
engine.Use(second)
|
2020-07-31 11:14:48 +08:00
|
|
|
engine.AddRoute(rest.Route{
|
2020-07-26 17:09:05 +08:00
|
|
|
Method: http.MethodGet,
|
|
|
|
Path: "/",
|
|
|
|
Handler: handle,
|
|
|
|
})
|
|
|
|
engine.Start()
|
|
|
|
}
|