mirror of
https://github.com/labstack/echo.git
synced 2025-01-24 03:16:14 +02:00
parent
73fa05f826
commit
aa5e552282
@ -90,15 +90,9 @@ func main() {
|
||||
// Echo instance
|
||||
e := echo.New()
|
||||
|
||||
//------------
|
||||
// Middleware
|
||||
//------------
|
||||
|
||||
// Recover
|
||||
e.Use(mw.Recover())
|
||||
|
||||
// Logger
|
||||
e.Use(mw.Logger())
|
||||
e.Use(mw.Recover())
|
||||
|
||||
// Routes
|
||||
e.Get("/", hello)
|
||||
|
29
echo.go
29
echo.go
@ -22,6 +22,7 @@ type (
|
||||
prefix string
|
||||
middleware []MiddlewareFunc
|
||||
maxParam byte
|
||||
notFoundHandler HandlerFunc
|
||||
httpErrorHandler HTTPErrorHandler
|
||||
binder BindFunc
|
||||
renderer Renderer
|
||||
@ -134,13 +135,16 @@ func New() (e *Echo) {
|
||||
//----------
|
||||
|
||||
e.MaxParam(5)
|
||||
e.notFoundHandler = func(c *Context) *HTTPError {
|
||||
return &HTTPError{Code: http.StatusNotFound}
|
||||
}
|
||||
e.HTTPErrorHandler(func(he *HTTPError, c *Context) {
|
||||
if he.Code == 0 {
|
||||
he.Code = http.StatusInternalServerError
|
||||
}
|
||||
if he.Message == "" {
|
||||
he.Message = http.StatusText(he.Code)
|
||||
if e.debug {
|
||||
if e.debug && he.Error != nil {
|
||||
he.Message = he.Error.Error()
|
||||
}
|
||||
}
|
||||
@ -321,18 +325,19 @@ func (e *Echo) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||
}
|
||||
c.reset(w, r, e)
|
||||
if h == nil {
|
||||
c.Error(&HTTPError{Code: http.StatusNotFound})
|
||||
} else {
|
||||
// Chain middleware with handler in the end
|
||||
for i := len(e.middleware) - 1; i >= 0; i-- {
|
||||
h = e.middleware[i](h)
|
||||
}
|
||||
|
||||
// Execute chain
|
||||
if he := h(c); he != nil {
|
||||
e.httpErrorHandler(he, c)
|
||||
}
|
||||
h = e.notFoundHandler
|
||||
}
|
||||
|
||||
// Chain middleware with handler in the end
|
||||
for i := len(e.middleware) - 1; i >= 0; i-- {
|
||||
h = e.middleware[i](h)
|
||||
}
|
||||
|
||||
// Execute chain
|
||||
if he := h(c); he != nil {
|
||||
e.httpErrorHandler(he, c)
|
||||
}
|
||||
|
||||
e.pool.Put(c)
|
||||
}
|
||||
|
||||
|
@ -61,8 +61,8 @@ func main() {
|
||||
e := echo.New()
|
||||
|
||||
// Middleware
|
||||
e.Use(mw.Recover())
|
||||
e.Use(mw.Logger())
|
||||
e.Use(mw.Recover())
|
||||
|
||||
// Routes
|
||||
e.Post("/users", createUser)
|
||||
|
@ -16,15 +16,9 @@ func main() {
|
||||
// Echo instance
|
||||
e := echo.New()
|
||||
|
||||
//------------
|
||||
// Middleware
|
||||
//------------
|
||||
|
||||
// Recover
|
||||
e.Use(mw.Recover())
|
||||
|
||||
// Logger
|
||||
e.Use(mw.Logger())
|
||||
e.Use(mw.Recover())
|
||||
|
||||
// Routes
|
||||
e.Get("/", hello)
|
||||
|
@ -23,12 +23,12 @@ func main() {
|
||||
// Middleware
|
||||
//------------
|
||||
|
||||
// Recover
|
||||
e.Use(mw.Recover())
|
||||
|
||||
// Logger
|
||||
e.Use(mw.Logger())
|
||||
|
||||
// Recover
|
||||
e.Use(mw.Recover())
|
||||
|
||||
// Basic auth
|
||||
e.Use(mw.BasicAuth(func(u, p string) bool {
|
||||
if u == "joe" && p == "secret" {
|
||||
|
@ -65,8 +65,8 @@ func main() {
|
||||
e := echo.New()
|
||||
|
||||
// Middleware
|
||||
e.Use(mw.Recover())
|
||||
e.Use(mw.Logger())
|
||||
e.Use(mw.Recover())
|
||||
|
||||
//------------------------
|
||||
// Third-party middleware
|
||||
|
@ -310,9 +310,8 @@ func (r *router) ServeHTTP(w http.ResponseWriter, req *http.Request) {
|
||||
h, _ := r.Find(req.Method, req.URL.Path, c)
|
||||
c.reset(w, req, r.echo)
|
||||
if h == nil {
|
||||
c.Error(&HTTPError{Code: http.StatusNotFound})
|
||||
} else {
|
||||
h(c)
|
||||
h = r.echo.notFoundHandler
|
||||
}
|
||||
h(c)
|
||||
r.echo.pool.Put(c)
|
||||
}
|
||||
|
@ -67,6 +67,7 @@ func main() {
|
||||
|
||||
// Middleware
|
||||
e.Use(mw.Logger())
|
||||
e.Use(mw.Recover())
|
||||
|
||||
// Routes
|
||||
e.Get("/", hello)
|
||||
|
Loading…
x
Reference in New Issue
Block a user