1
0
mirror of https://github.com/gofiber/fiber.git synced 2025-02-23 16:43:41 +00:00
fiber/.github/README.md

308 lines
10 KiB
Markdown
Raw Normal View History

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>
<!--<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">
</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
## ⚡️ 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 07:25:14 +01:00
app.Static("*", "./public/index.html")
// => http://localhost:3000/anything/returns/the/index/file
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-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-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-10 02:27:49 +01:00
// Last middleware
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-10 02:27:49 +01:00
app.Listen(3000)
}
```
### JSON Response
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
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-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()
app.Get("/json", func(c *fiber.Ctx) {
2020-02-13 07:25:14 +01:00
panic("Something went wrong!")
})
2020-02-13 07:25:14 +01:00
app.Recover(func(c *fiber.Ctx) {
c.Status(500).Send(c.Error())
})
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
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).