2020-02-11 04:07:30 -05:00
< p align = "center" >
2020-02-11 04:13:56 -05:00
< a href = "https://fiber.wiki" >
2020-02-11 04:39:57 -05:00
< img alt = "Fiber" height = "100" src = "https://github.com/gofiber/docs/blob/master/static/logo.svg" >
2020-02-11 04:13:56 -05:00
< / a >
2020-02-11 04:39:36 -05:00
< br > < br >
2020-02-12 18:59:07 +03:00
<!-- <a href="https://github.com/gofiber/fiber/blob/master/README.md">
2020-02-11 04:13:56 -05:00
< img height = "20px" src = "https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.4.6/flags/4x3/gb.svg" >
2020-02-12 18:59:07 +03:00
< / a > -->
< a href = "https://github.com/gofiber/fiber/blob/master/.github/README_ru.md" >
< img height = "20px" src = "https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.4.6/flags/4x3/ru.svg" >
2020-02-11 04:13:56 -05:00
< / a >
< a href = "https://github.com/gofiber/fiber/blob/master/.github/README_es.md" >
< img height = "20px" src = "https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.4.6/flags/4x3/es.svg" >
< / a >
< a href = "https://github.com/gofiber/fiber/blob/master/.github/README_ja.md" >
< img height = "20px" src = "https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.4.6/flags/4x3/jp.svg" >
< / a >
< a href = "https://github.com/gofiber/fiber/blob/master/.github/README_pt.md" >
< img height = "20px" src = "https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.4.6/flags/4x3/pt.svg" >
< / a >
< a href = "https://github.com/gofiber/fiber/blob/master/.github/README_zh-CN.md" >
< img height = "20px" src = "https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.4.6/flags/4x3/cn.svg" >
< / a >
< a href = "https://github.com/gofiber/fiber/blob/master/.github/README_de.md" >
< img height = "20px" src = "https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.4.6/flags/4x3/de.svg" >
< / a >
2020-02-12 01:04:13 +01:00
< a href = "https://github.com/gofiber/fiber/blob/master/.github/README_ko.md" >
< img height = "20px" src = "https://cdnjs.cloudflare.com/ajax/libs/flag-icon-css/3.4.6/flags/4x3/kr.svg" >
< / a >
2020-02-11 04:39:21 -05:00
< br > < br >
2020-02-11 04:13:56 -05:00
< a href = "https://github.com/gofiber/fiber/releases" >
< img src = "https://img.shields.io/github/release/gofiber/fiber?style=flat-square" >
< / a >
< a href = "https://fiber.wiki" >
< img src = "https://img.shields.io/badge/api-documentation-blue?style=flat-square" >
< / a >
< a href = "#" >
< img src = "https://img.shields.io/badge/goreport-A%2B-brightgreen?style=flat-square" >
< / a >
< a href = "https://gocover.io/github.com/gofiber/fiber" >
< img src = "https://img.shields.io/badge/coverage-91%25-brightgreen?style=flat-square" >
< / a >
< a href = "https://travis-ci.org/gofiber/fiber" >
< img src = "https://img.shields.io/travis/gofiber/fiber/master.svg?label=linux&style=flat-square" >
< / a >
< a href = "https://travis-ci.org/gofiber/fiber" >
< img src = "https://img.shields.io/travis/gofiber/fiber/master.svg?label=windows&style=flat-square" >
< / a >
2020-02-12 18:53:18 +03:00
< a href = "https://travis-ci.org/gofiber/fiber" >
< img src = "https://img.shields.io/travis/gofiber/fiber/master.svg?label=osx&style=flat-square" >
< / a >
2020-02-11 04:35:28 -05:00
< / p >
< p align = "center" >
2020-02-11 04:44:08 -05:00
< b > Fiber< / b > is an < a href = "https://github.com/expressjs/express" > Express< / a > inspired < b > web framework< / b > build on top of < a href = "https://github.com/valyala/fasthttp" > Fasthttp< / a > , the < b > fastest< / b > HTTP engine for < a href = "https://golang.org/doc/" > Go< / a > . Designed to < b > ease< / b > things up for < b > fast< / b > development with < b > zero memory allocation< / b > and < b > performance< / b > in mind.
2020-02-11 04:13:56 -05:00
< / p >
2020-02-11 04:09:03 -05:00
2020-02-11 06:35:19 +01:00
## ⚡️ Quickstart
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
```go
package main
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
import "github.com/gofiber/fiber"
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
func main() {
app := fiber.New()
app.Get("/", func(c *fiber.Ctx) {
c.Send("Hello, World!")
})
2020-02-01 17:50:43 +03:00
2020-02-10 02:27:49 +01:00
app.Listen(3000)
}
```
2020-02-01 17:50:43 +03:00
2020-02-10 02:27:49 +01:00
## ⚙️ Installation
2020-01-08 16:43:58 -05:00
2020-02-10 02:27:49 +01:00
First of all, [download ](https://golang.org/dl/ ) and install Go. `1.11` or higher is required.
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
Installation is done using the [`go get` ](https://golang.org/cmd/go/#hdr-Add_dependencies_to_current_module_and_install_them ) command:
2020-01-14 05:44:59 +01:00
2020-02-10 02:27:49 +01:00
```bash
go get github.com/gofiber/fiber
```
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
## 🤖 Benchmarks
2020-01-14 05:44:59 +01:00
2020-02-10 02:27:49 +01:00
These tests are performed by [TechEmpower ](https://github.com/TechEmpower/FrameworkBenchmarks ) and [Go Web ](https://github.com/smallnest/go-web-framework-benchmark ). If you want to see all results, please visit our [Wiki ](https://fiber.wiki/benchmarks ).
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
< p float = "left" align = "middle" >
2020-02-11 02:31:22 +01:00
< img src = "https://github.com/gofiber/docs/blob/master/.gitbook/assets//benchmark-pipeline.png" width = "49%" >
< img src = "https://github.com/gofiber/docs/blob/master/.gitbook/assets//benchmark_alloc.png" width = "49%" >
2020-02-10 02:27:49 +01:00
< / p >
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
## 🎯 Features
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
- Robust [routing ](https://fiber.wiki/routing )
- Serve [static files ](https://fiber.wiki/application#static )
- Extreme [performance ](https://fiber.wiki/benchmarks )
- [Low memory ](https://fiber.wiki/benchmarks ) footprint
2020-02-11 04:44:08 -05:00
- [API endpoints ](https://fiber.wiki/context )
2020-02-10 02:27:49 +01:00
- Middleware & [Next ](https://fiber.wiki/context#next ) support
- [Rapid ](https://dev.to/koddr/welcome-to-fiber-an-express-js-styled-fastest-web-framework-written-with-on-golang-497 ) server-side programming
2020-02-11 04:26:03 +01:00
- Translated in [5 languages ](https://fiber.wiki/ )
2020-02-10 02:27:49 +01:00
- And much more, [explore Fiber ](https://fiber.wiki/ )
2020-01-08 16:43:58 -05:00
2020-02-10 02:27:49 +01:00
## 💡 Philosophy
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
New gophers that make the switch from [Node.js ](https://nodejs.org/en/about/ ) to [Go ](https://golang.org/doc/ ) are dealing with a learning curve before they can start building their web applications or microservices. Fiber, as a **web framework** , was created with the idea of **minimalism** and follow **UNIX way** , so that new gophers can quickly enter the world of Go with a warm and trusted welcome.
2020-02-01 17:32:48 +03:00
2020-02-11 04:44:08 -05:00
Fiber is **inspired** by Express, the most popular web framework on the Internet. We combined the **ease** of Express and **raw performance** of Go. If you have ever implemented a web application on Node.js (_using Express or similar_), then many methods and principles will seem **very common** to you.
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
## 👀 Examples
2020-01-08 16:43:58 -05:00
2020-02-10 02:27:49 +01:00
Listed below are some of the common examples. If you want to see more code examples, please visit our [Recipes repository ](https://github.com/gofiber/recipes ) or visit our [API documentation ](https://fiber.wiki ).
2020-01-08 16:43:58 -05:00
2020-02-10 02:27:49 +01:00
### Static files
```go
2020-01-08 16:43:58 -05:00
func main() {
2020-01-14 05:46:21 +01:00
app := fiber.New()
2020-01-20 04:33:55 +01:00
2020-02-10 02:27:49 +01:00
app.Static("./public")
// => http://localhost:3000/js/script.js
// => http://localhost:3000/css/style.css
app.Static("/prefix", "./public")
// => http://localhost:3000/prefix/js/script.js
// => http://localhost:3000/prefix/css/style.css
2020-02-13 23:42:55 +01:00
2020-02-13 07:25:14 +01:00
app.Static("*", "./public/index.html")
// => http://localhost:3000/anything/returns/the/index/file
2020-02-01 19:42:40 +03:00
2020-02-10 02:27:49 +01:00
app.Listen(3000)
2020-01-08 16:43:58 -05:00
}
```
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
### Routing
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
```go
func main() {
app := fiber.New()
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
// GET /john
app.Get("/:name", func(c *fiber.Ctx) {
fmt.Printf("Hello %s!", c.Params("name"))
// => Hello john!
})
2020-01-08 16:43:58 -05:00
2020-02-10 02:27:49 +01:00
// GET /john
app.Get("/:name/:age?", func(c *fiber.Ctx) {
fmt.Printf("Name: %s, Age: %s", c.Params("name"), c.Params("age"))
// => Name: john, Age:
})
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
// GET /api/register
app.Get("/api*", func(c *fiber.Ctx) {
fmt.Printf("/api%s", c.Params("*"))
// => /api/register
})
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
app.Listen(3000)
}
```
2020-01-08 16:43:58 -05:00
2020-02-10 02:27:49 +01:00
### Middleware
2020-01-16 10:51:56 +01:00
2020-02-10 02:27:49 +01:00
```go
2020-01-16 10:51:56 +01:00
func main() {
app := fiber.New()
2020-02-01 19:42:40 +03:00
2020-02-10 02:27:49 +01:00
// Match any post route
app.Post(func(c *fiber.Ctx) {
user, pass, ok := c.BasicAuth()
if !ok || user != "john" || pass != "doe" {
c.Status(403).Send("Sorry John")
return
}
c.Next()
})
2020-02-01 19:42:40 +03:00
2020-02-10 02:27:49 +01:00
// Match all routes starting with /api
app.Use("/api", func(c *fiber.Ctx) {
c.Set("Access-Control-Allow-Origin", "*")
c.Set("Access-Control-Allow-Headers", "X-Requested-With")
c.Next()
})
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
// Optional param
app.Post("/api/register", func(c *fiber.Ctx) {
username := c.Body("username")
password := c.Body("password")
// ..
})
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
app.Listen(3000)
}
2020-01-08 16:43:58 -05:00
```
2020-02-10 02:27:49 +01:00
### 404 Handling
2020-02-01 17:32:48 +03:00
2020-01-08 16:43:58 -05:00
```go
2020-01-16 10:51:56 +01:00
func main() {
app := fiber.New()
2020-01-20 04:33:55 +01:00
2020-02-10 02:27:49 +01:00
// Serve static files from "public" directory
app.Static("./public")
2020-02-01 19:42:40 +03:00
2020-02-10 02:27:49 +01:00
// Last middleware
2020-02-13 23:42:55 +01:00
app.Use(func(c *fiber.Ctx) {
2020-02-10 02:27:49 +01:00
c.SendStatus(404) // => 404 "Not Found"
2020-01-20 04:33:55 +01:00
})
2020-02-01 19:42:40 +03:00
2020-02-10 02:27:49 +01:00
app.Listen(3000)
}
```
### JSON Response
2020-02-01 19:42:40 +03:00
2020-02-10 02:27:49 +01:00
```go
func main() {
app := fiber.New()
type User struct {
Name string `json:"name"`
Age int `json:"age"`
}
// Serialize JSON
2020-02-13 23:42:55 +01:00
app.Get("/json", func(c *fiber.Ctx) {
2020-02-10 02:27:49 +01:00
c.JSON(& User{"John", 20})
2020-01-16 10:51:56 +01:00
})
2020-02-01 19:42:40 +03:00
2020-02-10 02:27:49 +01:00
app.Listen(3000)
2020-01-16 10:51:56 +01:00
}
2020-01-08 16:43:58 -05:00
```
2020-01-06 21:41:00 -05:00
2020-02-13 07:25:14 +01:00
### Recover
```go
func main() {
app := fiber.New()
2020-02-13 23:42:55 +01:00
app.Get("/json", func(c *fiber.Ctx) {
2020-02-13 07:25:14 +01:00
panic("Something went wrong!")
})
2020-02-13 23:42:55 +01:00
2020-02-13 07:25:14 +01:00
app.Recover(func(c *fiber.Ctx) {
c.Status(500).Send(c.Error())
})
2020-02-13 23:42:55 +01:00
2020-02-13 07:25:14 +01:00
app.Listen(3000)
}
```
2020-02-10 02:27:49 +01:00
## 💬 Media
- [Welcome to Fiber — an Express.js styled web framework written in Go with ❤️ ](https://dev.to/koddr/welcome-to-fiber-an-express-js-styled-fastest-web-framework-written-with-on-golang-497 ) _by [Vic Shóstak](https://github.com/koddr), 03 Feb 2020_
## 👍 Contribute
2020-02-12 18:59:07 +03:00
If you want to say **thank you** and/or support the active development of `Fiber` :
2020-02-01 17:50:43 +03:00
2020-02-11 06:36:34 +01:00
1. Add a [GitHub Star ](https://github.com/gofiber/fiber/stargazers ) to the project.
2020-02-11 06:37:04 +01:00
2. Tweet about the project [on your Twitter ](https://twitter.com/intent/tweet?text=%F0%9F%9A%80%20Fiber%20%E2%80%94%20is%20an%20Express.js%20inspired%20web%20framework%20build%20on%20Fasthttp%20for%20%23Go%20https%3A%2F%2Fgithub.com%2Fgofiber%2Ffiber ).
2020-02-10 02:27:49 +01:00
3. Write a review or tutorial on [Medium ](https://medium.com/ ), [Dev.to ](https://dev.to/ ) or personal blog.
2020-02-13 07:28:44 +01:00
4. Help us to translate this `README` to another language.
2020-01-16 10:51:56 +01:00
2020-02-01 17:32:48 +03:00
2020-02-12 03:54:54 +01:00
## ☕ Supporters
2020-02-13 07:30:51 +01:00
< a href = "https://www.buymeacoffee.com/fenny" target = "_blank" > < img src = "https://github.com/gofiber/docs/blob/master/static/buy-morning-coffee-3x.gif" alt = "Buy Me A Coffee" height = "100" > < / a >
2020-02-12 03:54:54 +01:00
< table >
< tr >
2020-02-13 07:33:00 +01:00
< td align = "center" >
2020-02-13 08:18:50 +01:00
< a href = "https://github.com/bihe" >
< img src = "https://avatars1.githubusercontent.com/u/635852?s=460&v=4" width = "75" > < / br >
2020-02-13 08:17:48 +01:00
< sub > < b > HenrikBinggl< / b > < / sub >
2020-02-13 07:33:00 +01:00
< / a >
2020-02-13 08:17:48 +01:00
< / td >
2020-02-12 03:54:54 +01:00
< td align = "center" >
2020-02-13 08:17:48 +01:00
< a href = "https://github.com/koddr" >
< img src = "https://avatars0.githubusercontent.com/u/11155743?s=460&v=4" width = "75" > < / br >
< sub > < b > koddr< / b > < / sub >
< / a >
< / td >
< td align = "center" >
< a href = "https://github.com/MarvinJWendt" >
< img src = "https://avatars1.githubusercontent.com/u/31022056?s=460&v=4" width = "75" > < / br >
< sub > < b > MarvinJWendt< / b > < / sub >
< / a >
< / td >
2020-02-13 07:27:47 +01:00
< td align = "center" >
2020-02-13 08:18:50 +01:00
< a href = "https://github.com/toishy" >
< img src = "https://avatars1.githubusercontent.com/u/31921460?s=460&v=4" width = "75" > < / br >
2020-02-13 08:17:48 +01:00
< sub > < b > ToishY< / b > < / sub >
< / a >
< / td >
2020-02-12 03:54:54 +01:00
< / tr >
2020-02-13 07:30:51 +01:00
< / table >
2020-02-13 07:28:44 +01:00
2020-02-12 03:54:54 +01:00
## ⭐️ Stars
2020-02-01 17:32:48 +03:00
2020-02-04 16:06:14 +01:00
< a href = "https://starchart.cc/gofiber/fiber" rel = "nofollow" > < img src = "https://starchart.cc/gofiber/fiber.svg" alt = "Stars over time" style = "max-width:100%;" > < / a >
2020-02-01 17:32:48 +03:00
2020-02-10 02:27:49 +01:00
## ⚠️ License
2020-01-16 10:51:56 +01:00
2020-02-12 23:49:06 +03:00
`Fiber` is free and open-source software licensed under the [MIT License ](https://github.com/gofiber/fiber/blob/master/LICENSE ).