1
0
mirror of https://github.com/labstack/echo.git synced 2025-01-07 23:01:56 +02:00
echo/website/content/guide/error-handling.md
Vishal Rana 1efe837fdd Updated docs
Signed-off-by: Vishal Rana <vr@labstack.com>
2015-10-05 15:52:07 -07:00

1002 B

title menu
Error Handling
main
parent weight
guide 7

Echo advocates centralized HTTP error handling by returning error from middleware and handlers.

It allows you to:

  • Debug by writing stack trace to the HTTP response.
  • Customize HTTP responses.
  • Recover from panics inside middleware or handlers.

For example, when basic auth middleware finds invalid credentials it returns 401 - Unauthorized error, aborting the current HTTP request.

package main

import (
	"net/http"

	"github.com/labstack/echo"
)

func main() {
	e := echo.New()
	e.Use(func(c *echo.Context) error {
		// Extract the credentials from HTTP request header and perform a security
		// check

		// For invalid credentials
		return echo.NewHTTPError(http.StatusUnauthorized)
	})
	e.Get("/welcome", welcome)
	e.Run(":1323")
}

func welcome(c *echo.Context) error {
	return c.String(http.StatusOK, "Welcome!")
}

See how HTTPErrorHandler handles it.