1
0
mirror of https://github.com/labstack/echo.git synced 2025-01-18 02:58:38 +02:00
echo/website/docs/index.md
Vishal Rana c58ec742a9 Enhanced router priority
Signed-off-by: Vishal Rana <vr@labstack.com>
2015-05-09 22:06:13 -07:00

3.0 KiB

Echo

Build simple and performant systems!


Overview

Echo is a fast HTTP router (zero memory allocation) and micro web framework in Go.

Features

  • Fast HTTP router which smartly prioritize routes.
  • Extensible middleware/handler, supports:
    • Middleware
      • func(*echo.Context)
      • func(*echo.Context) *echo.HTTPError
      • func(echo.HandlerFunc) echo.HandlerFunc
      • func(http.Handler) http.Handler
      • http.Handler
      • http.HandlerFunc
      • func(http.ResponseWriter, *http.Request)
      • func(http.ResponseWriter, *http.Request) *echo.HTTPError
    • Handler
      • echo.HandlerFunc
      • func(*echo.Context) *echo.HTTPError
      • func(*echo.Context)
      • http.Handler
      • http.HandlerFunc
      • func(http.ResponseWriter, *http.Request)
      • func(http.ResponseWriter, *http.Request) *echo.HTTPError
  • Sub routing with groups.
  • Handy encoding/decoding functions.
  • Serve static files, including index.
  • Centralized HTTP error handling.
  • Use a customized function to bind HTTP request body to a Go type.
  • Register a view render so you can use any HTML template engine.

Getting Started

Installation

$ go get github.com/labstack/echo

###Hello, World!

Create server.go with the following content

package main

import (
	"net/http"

	"github.com/labstack/echo"
	mw "github.com/labstack/echo/middleware"
)

// Handler
func hello(c *echo.Context) *echo.HTTPError {
	return c.String(http.StatusOK, "Hello, World!\n")
}

func main() {
	// Echo instance
	e := echo.New()

	// Middleware
	e.Use(mw.Logger)

	// Routes
	e.Get("/", hello)

	// Start server
	e.Run(":4444")
}

echo.New() returns a new instance of Echo.

e.Use(mw.Logger) adds logging middleware to the chain. It logs every HTTP request made to the server, producing output

2015/04/25 12:15:20 GET / 200 7.544µs
2015/04/25 12:15:26 GET / 200 3.681µs
2015/04/25 12:15:29 GET / 200 5.434µs

e.Get("/", hello) Registers a GET route for path / with hello handler, so whenever server receives an HTTP request at /, hello handler is called.

In hello handler c.String(http.StatusOK, "Hello, World!\n") sends a text/plain HTTP response to the client with 200 status code.

e.Run(":4444") Starts HTTP server at network address :4444.

Now start the server using command

$ go run server.go

Browse to http://localhost:4444 and you should see Hello, World! on the page.

Next?

Contribute

Use issues for everything

  • Report issues
  • Discuss before sending pull request
  • Suggest new features
  • Improve/fix documentation

Credits

License

MIT