2016-03-10 21:40:25 -08:00
# *NOTICE*
- Master branch, website and godoc now points to Echo v2.
2016-03-10 22:22:42 -08:00
- It is advisable to migrate to v2. (https://labstack.com/echo/guide/migrating)
2016-03-10 21:40:25 -08:00
- Looking for v1?
- Installation: Use a package manager (https://github.com/Masterminds/glide, it's nice!) to get stable v1 release/commit or use `go get gopkg.in/labstack/echo.v1` .
- Godoc: https://godoc.org/gopkg.in/labstack/echo.v1
- Docs: https://github.com/labstack/echo/tree/v1.3/website/content
2015-12-21 15:20:49 -08:00
2015-10-08 13:54:31 -07:00
# [Echo](http://labstack.com/echo) [![GoDoc](http://img.shields.io/badge/go-documentation-blue.svg?style=flat-square)](http://godoc.org/github.com/labstack/echo) [![License](http://img.shields.io/badge/license-mit-blue.svg?style=flat-square)](https://raw.githubusercontent.com/labstack/echo/master/LICENSE) [![Build Status](http://img.shields.io/travis/labstack/echo.svg?style=flat-square)](https://travis-ci.org/labstack/echo) [![Coverage Status](http://img.shields.io/coveralls/labstack/echo.svg?style=flat-square)](https://coveralls.io/r/labstack/echo) [![Join the chat at https://gitter.im/labstack/echo](https://img.shields.io/badge/gitter-join%20chat-brightgreen.svg?style=flat-square)](https://gitter.im/labstack/echo)
2015-06-30 12:10:35 -07:00
2016-02-09 13:39:47 -08:00
**A fast and unfancy micro web framework for Go.**
2016-02-09 11:46:08 -08:00
2016-03-10 22:22:42 -08:00
## Features
- Fast HTTP router which smartly prioritize routes.
- Run with standard HTTP server or FastHTTP server.
- Extensible middleware framework.
- Router groups with nesting.
- Handy functions to send variety of HTTP responses.
- Centralized HTTP error handling.
- Template rendering with any template engine.
## Performance
Based on [vishr/go-http-routing-benchmark] (https://github.com/vishr/go-http-routing-benchmark), June 5, 2015.
![Performance ](http://i.imgur.com/hB2qdRS.png )
## Getting Started
### Installation
```sh
$ go get github.com/labstack/echo
```
### Hello, World!
Create `main.go`
2016-02-09 11:46:08 -08:00
```go
package main
import (
2016-03-10 22:22:42 -08:00
"net/http"
2016-02-09 11:46:08 -08:00
"github.com/labstack/echo"
2016-02-09 17:16:46 -08:00
"github.com/labstack/echo/engine/standard"
2016-03-10 21:40:25 -08:00
"github.com/labstack/echo/middleware"
2016-02-09 11:46:08 -08:00
)
2016-03-10 22:22:42 -08:00
// Handler
func hello() echo.HandlerFunc {
return func(c echo.Context) error {
return c.String(http.StatusOK, "Hello, World!\n")
}
}
2016-02-09 11:46:08 -08:00
func main() {
2016-03-10 22:22:42 -08:00
// Echo instance
2016-02-09 11:46:08 -08:00
e := echo.New()
2016-03-10 22:22:42 -08:00
// Middleware
2016-03-10 21:40:25 -08:00
e.Use(middleware.Logger())
e.Use(middleware.Recover())
2016-02-09 11:46:08 -08:00
2016-03-10 22:22:42 -08:00
// Routes
e.Get("/", hello())
2016-02-09 11:46:08 -08:00
2016-03-10 22:22:42 -08:00
// Start server
2016-03-05 20:03:11 -08:00
e.Run(standard.New(":1323"))
2016-02-09 11:46:08 -08:00
}
```
2015-03-12 14:51:39 -07:00
2016-03-10 22:22:42 -08:00
Start server
2015-04-18 16:47:48 -07:00
2016-03-10 22:22:42 -08:00
```sh
$ go run main.go
```
2015-04-18 16:47:48 -07:00
2016-03-10 22:22:42 -08:00
Browse to [http://localhost:1323 ](http://localhost:1323 ) and you should see
Hello, World! on the page.
2015-04-16 10:18:35 -07:00
2016-03-10 22:22:42 -08:00
### Next?
2016-03-11 18:26:16 -08:00
- Browse [recipes ](https://labstack.com/echo/recipes/hello-world )
- Head over to [guide ](https://labstack.com/echo/guide/installation )
2015-04-16 10:18:35 -07:00
2015-04-25 16:10:28 -07:00
## Contribute
**Use issues for everything**
2015-04-26 22:41:41 -07:00
2016-03-10 22:22:42 -08:00
- Report issues
- Discuss before sending pull request
- Suggest new features
2015-04-25 16:10:28 -07:00
- Improve/fix documentation
## Credits
- [Vishal Rana ](https://github.com/vishr ) - Author
- [Nitin Rana ](https://github.com/nr17 ) - Consultant
- [Contributors ](https://github.com/labstack/echo/graphs/contributors )
2016-03-10 22:22:42 -08:00
## License
[MIT ](https://github.com/labstack/echo/blob/master/LICENSE )