mirror of
https://github.com/gofiber/fiber.git
synced 2025-05-31 11:52:41 +00:00
669 lines
41 KiB
Markdown
669 lines
41 KiB
Markdown
<p align="center">
|
||
<a href="https://gofiber.io">
|
||
<img alt="Fiber" height="125" src="https://raw.githubusercontent.com/gofiber/docs/master/static/fiber_v2_logo.svg">
|
||
</a>
|
||
<br>
|
||
<!-- base64 flags are available at https://www.phoca.cz/cssflags/ -->
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README.md">
|
||
<img height="20px" src="https://img.shields.io/badge/EN-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_ru.md">
|
||
<img height="20px" src="https://img.shields.io/badge/RU-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_es.md">
|
||
<img height="20px" src="https://img.shields.io/badge/ES-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_ja.md">
|
||
<img height="20px" src="https://img.shields.io/badge/JA-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_pt.md">
|
||
<img height="20px" src="https://img.shields.io/badge/PT-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_zh-CN.md">
|
||
<img height="20px" src="https://img.shields.io/badge/CN-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<!-- <a href="https://github.com/gofiber/fiber/blob/master/.github/README_zh-TW.md">
|
||
<img height="20px" src="https://img.shields.io/badge/TW-flag.svg?color=555555&style=flat&logo=">
|
||
</a> -->
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_de.md">
|
||
<img height="20px" src="https://img.shields.io/badge/DE-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_nl.md">
|
||
<img height="20px" src="https://img.shields.io/badge/NL-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_ko.md">
|
||
<img height="20px" src="https://img.shields.io/badge/KO-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_fr.md">
|
||
<img height="20px" src="https://img.shields.io/badge/FR-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_tr.md">
|
||
<img height="20px" src="https://img.shields.io/badge/TR-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_id.md">
|
||
<img height="20px" src="https://img.shields.io/badge/ID-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_he.md">
|
||
<img height="20px" src="https://img.shields.io/badge/HE-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_sa.md">
|
||
<img height="20px" src="https://img.shields.io/badge/SA-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_fa.md">
|
||
<img height="20px" src="https://img.shields.io/badge/IR-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_it.md">
|
||
<img height="20px" src="https://img.shields.io/badge/IT-flag.svg?color=555555&style=flat&logo=">
|
||
</a>
|
||
<br>
|
||
<a href="https://pkg.go.dev/github.com/gofiber/fiber/v2#pkg-overview">
|
||
<img src="https://img.shields.io/badge/%F0%9F%93%9A%20godoc-pkg-00ACD7.svg?color=00ACD7&style=flat">
|
||
</a>
|
||
<a href="https://goreportcard.com/report/github.com/gofiber/fiber/v2">
|
||
<img src="https://img.shields.io/badge/%F0%9F%93%9D%20goreport-A%2B-75C46B">
|
||
</a>
|
||
<a href="https://gocover.io/github.com/gofiber/fiber">
|
||
<img src="https://img.shields.io/badge/%F0%9F%94%8E%20gocover-97.8%25-75C46B.svg?style=flat">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/actions?query=workflow%3ASecurity">
|
||
<img src="https://img.shields.io/github/workflow/status/gofiber/fiber/Security?label=%F0%9F%94%91%20gosec&style=flat&color=75C46B">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/actions?query=workflow%3ATest">
|
||
<img src="https://img.shields.io/github/workflow/status/gofiber/fiber/Test?label=%F0%9F%A7%AA%20tests&style=flat&color=75C46B">
|
||
</a>
|
||
<a href="https://docs.gofiber.io">
|
||
<img src="https://img.shields.io/badge/%F0%9F%92%A1%20fiber-docs-00ACD7.svg?style=flat">
|
||
</a>
|
||
<a href="https://gofiber.io/discord">
|
||
<img src="https://img.shields.io/discord/704680098577514527?style=flat&label=%F0%9F%92%AC%20discord&color=00ACD7">
|
||
</a>
|
||
</p>
|
||
<p align="center">
|
||
<b>Fiber</b>是移植NodeJS的<a href="https://github.com/expressjs/express">Express</a><b>框架</b>改以<a href="https://go.dev/doc/">Go</a>語言編寫。<b>本套件基於</b><a href="https://github.com/valyala/fasthttp">Fasthttp</a>,Fasthttp有<b>不分配記憶體空間</b>和<b>Request Pool</b>的特性,在網路效能方面有著顯著的效能。
|
||
</p>
|
||
|
||
## ⚡️ 快速入門
|
||
|
||
```go
|
||
package main
|
||
|
||
import "github.com/gofiber/fiber/v2"
|
||
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
app.Get("/", func(c *fiber.Ctx) error {
|
||
return c.SendString("Hello, World 👋!")
|
||
})
|
||
|
||
app.Listen(":3000")
|
||
}
|
||
```
|
||
|
||
## 🤖 效能
|
||
|
||
本測試使用[TechEmpower](https://www.techempower.com/benchmarks/#section=data-r19&hw=ph&test=plaintext)和[Go Web 框架效能測試](https://github.com/smallnest/go-web-framework-benchmark)。如果要看全部的執行結果,請到[Wiki](https://docs.gofiber.io/extra/benchmarks) 。
|
||
|
||
<p float="left" align="middle">
|
||
<img src="https://raw.githubusercontent.com/gofiber/docs/master/.gitbook/assets/benchmark-pipeline.png" width="49%">
|
||
<img src="https://raw.githubusercontent.com/gofiber/docs/master/.gitbook/assets/benchmark_alloc.png" width="49%">
|
||
</p>
|
||
|
||
## ⚙️ 安裝
|
||
|
||
確保已安裝 Go 版本 `1.14` 或以上 ([下載](https://go.dev/dl/))。
|
||
|
||
建立文件夾並在文件夾內執行 `go mod init github.com/your/repo` ([了解更多](https://go.dev/blog/using-go-modules)) 指令建立專案,然後使用 [`go get`](https://pkg.go.dev/cmd/go/#hdr-Add_dependencies_to_current_module_and_install_them) 指令下載 fiber :
|
||
|
||
```bash
|
||
go get -u github.com/gofiber/fiber/v2
|
||
```
|
||
|
||
## 🎯 功能
|
||
|
||
- 強大的[路由](https://docs.gofiber.io/routing)
|
||
- [靜態檔案](https://docs.gofiber.io/api/app#static)服務
|
||
- [超快速](https://docs.gofiber.io/extra/benchmarks)
|
||
- [佔用很少記憶體](https://docs.gofiber.io/extra/benchmarks)
|
||
- 支援 Express 的[API](https://docs.gofiber.io/api/ctx)
|
||
- 支援中介器和[下一步](https://docs.gofiber.io/api/ctx#next)
|
||
- [立即上手](https://dev.to/koddr/welcome-to-fiber-an-express-js-styled-fastest-web-framework-written-with-on-golang-497)
|
||
- [樣板引擎](https://github.com/gofiber/template)
|
||
- 支援[WebSocket](https://github.com/gofiber/websocket)
|
||
- [Server-Sent events](https://github.com/gofiber/recipes/tree/master/sse)
|
||
- 支援[限速](https://docs.gofiber.io/api/middleware/limiter)
|
||
- 被翻譯成[15種語言](https://docs.gofiber.io/)
|
||
- 豐富的[文件](https://docs.gofiber.io/)
|
||
|
||
## 💡 理念
|
||
|
||
不少[Node.js](https://nodejs.org/en/about/)的工程師跳到[Go](https://go.dev/doc/)必須學習一些知識,因此做了一個跟 Express 一樣的 Fiber 省這些麻煩。設計還是照原本的**極簡主義**還有遵循**UNIX 慣例**,因此新手們可以**無痛**迅速進入 Go 的世界。
|
||
|
||
Fiber **受到** 網路上最流行的 Web 框架 ExpressJS**啟發**,結合 Express 的**易用性**和 Go 的**高效能**。若你之前用過 Node.js 寫 Web 應用(_使用 ExpressJS/Koa 或類似工具_),那你已經**上手**了。
|
||
|
||
有什麼問題請發[issues](https://github.com/gofiber/fiber/issues)或加入 Discord [channel](https://gofiber.io/discord)討論,我們想要創造**快速**、**彈性**、**友善**的社群給**任何人**使用!就像 Express 那樣。
|
||
|
||
## 限制
|
||
* 由於 Fiber 使用了 unsafe,該庫可能並不總是與最新的 Go 版本兼容。 Fiber 2.29.0 已經用 Go 版本 1.14 到 1.18 進行了測試。
|
||
* Fiber 與 net/http 接口不兼容。 這意味著您將無法使用 gqlgen、go-swagger 或任何其他屬於 net/http 生態系統的項目。
|
||
|
||
## 👀 範例
|
||
|
||
以下是一些常見範例。
|
||
|
||
> 更多程式碼在[範例專案](https://github.com/gofiber/recipes)中或直接看[API 文件](https://docs.gofiber.io)。
|
||
|
||
#### 📖 [**Basic Routing**](https://docs.gofiber.io/#basic-routing)
|
||
|
||
```go
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
// GET /api/register
|
||
app.Get("/api/*", func(c *fiber.Ctx) error {
|
||
msg := fmt.Sprintf("✋ %s", c.Params("*"))
|
||
return c.SendString(msg) // => ✋ register
|
||
})
|
||
|
||
// GET /flights/LAX-SFO
|
||
app.Get("/flights/:from-:to", func(c *fiber.Ctx) error {
|
||
msg := fmt.Sprintf("💸 From: %s, To: %s", c.Params("from"), c.Params("to"))
|
||
return c.SendString(msg) // => 💸 From: LAX, To: SFO
|
||
})
|
||
|
||
// GET /dictionary.txt
|
||
app.Get("/:file.:ext", func(c *fiber.Ctx) error {
|
||
msg := fmt.Sprintf("📃 %s.%s", c.Params("file"), c.Params("ext"))
|
||
return c.SendString(msg) // => 📃 dictionary.txt
|
||
})
|
||
|
||
// GET /john/75
|
||
app.Get("/:name/:age/:gender?", func(c *fiber.Ctx) error {
|
||
msg := fmt.Sprintf("👴 %s is %s years old", c.Params("name"), c.Params("age"))
|
||
return c.SendString(msg) // => 👴 john is 75 years old
|
||
})
|
||
|
||
// GET /john
|
||
app.Get("/:name", func(c *fiber.Ctx) error {
|
||
msg := fmt.Sprintf("Hello, %s 👋!", c.Params("name"))
|
||
return c.SendString(msg) // => Hello john 👋!
|
||
})
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
|
||
```
|
||
|
||
#### 📖 [**路線命名**](https://docs.gofiber.io/api/app#name)
|
||
|
||
```go
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
// GET /api/register
|
||
app.Get("/api/*", func(c *fiber.Ctx) error {
|
||
msg := fmt.Sprintf("✋ %s", c.Params("*"))
|
||
return c.SendString(msg) // => ✋ register
|
||
}).Name("api")
|
||
|
||
data, _ := json.MarshalIndent(app.GetRoute("api"), "", " ")
|
||
fmt.Print(string(data))
|
||
// Prints:
|
||
// {
|
||
// "method": "GET",
|
||
// "name": "api",
|
||
// "path": "/api/*",
|
||
// "params": [
|
||
// "*1"
|
||
// ]
|
||
// }
|
||
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
|
||
```
|
||
|
||
#### 📖 [**提供靜態文件**](https://docs.gofiber.io/api/app#static)
|
||
|
||
```go
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
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
|
||
|
||
app.Static("*", "./public/index.html")
|
||
// => http://localhost:3000/any/path/shows/index/html
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
|
||
```
|
||
|
||
#### 📖 [**Middleware & Next**](https://docs.gofiber.io/api/ctx#next)
|
||
|
||
```go
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
// Match any route
|
||
app.Use(func(c *fiber.Ctx) error {
|
||
fmt.Println("🥇 First handler")
|
||
return c.Next()
|
||
})
|
||
|
||
// Match all routes starting with /api
|
||
app.Use("/api", func(c *fiber.Ctx) error {
|
||
fmt.Println("🥈 Second handler")
|
||
return c.Next()
|
||
})
|
||
|
||
// GET /api/register
|
||
app.Get("/api/list", func(c *fiber.Ctx) error {
|
||
fmt.Println("🥉 Last handler")
|
||
return c.SendString("Hello, World 👋!")
|
||
})
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
|
||
```
|
||
|
||
<details>
|
||
<summary>📚 顯示更多範例</summary>
|
||
|
||
### 界面引擎
|
||
|
||
📖 [設定](https://docs.gofiber.io/api/fiber#config)
|
||
📖 [引擎](https://github.com/gofiber/template)
|
||
📖 [渲染](https://docs.gofiber.io/api/ctx#render)
|
||
|
||
當不指定樣板引擎時 Fiber 預設用[html/template](https://pkg.go.dev/html/template/)。
|
||
|
||
如果你想要執行部份或用別的樣板引擎[amber](https://github.com/eknkc/amber)、[handlebars](https://github.com/aymerick/raymond)、[mustache](https://github.com/cbroglie/mustache)、[pug](https://github.com/Joker/jade)之類…請參考符合多樣板引擎的[樣板](https://github.com/gofiber/template)套件。
|
||
|
||
```go
|
||
package main
|
||
|
||
import (
|
||
"github.com/gofiber/fiber/v2"
|
||
"github.com/gofiber/template/pug"
|
||
)
|
||
|
||
func main() {
|
||
// You can setup Views engine before initiation app:
|
||
app := fiber.New(fiber.Config{
|
||
Views: pug.New("./views", ".pug"),
|
||
})
|
||
|
||
// And now, you can call template `./views/home.pug` like this:
|
||
app.Get("/", func(c *fiber.Ctx) error {
|
||
return c.Render("home", fiber.Map{
|
||
"title": "Homepage",
|
||
"year": 1999,
|
||
})
|
||
})
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
|
||
```
|
||
|
||
### 鏈式路線分組
|
||
|
||
📖 [Group](https://docs.gofiber.io/api/app#group)
|
||
|
||
```go
|
||
func middleware(c *fiber.Ctx) error {
|
||
fmt.Println("Don't mind me!")
|
||
return c.Next()
|
||
}
|
||
|
||
func handler(c *fiber.Ctx) error {
|
||
return c.SendString(c.Path())
|
||
}
|
||
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
// Root API route
|
||
api := app.Group("/api", middleware) // /api
|
||
|
||
// API v1 routes
|
||
v1 := api.Group("/v1", middleware) // /api/v1
|
||
v1.Get("/list", handler) // /api/v1/list
|
||
v1.Get("/user", handler) // /api/v1/user
|
||
|
||
// API v2 routes
|
||
v2 := api.Group("/v2", middleware) // /api/v2
|
||
v2.Get("/list", handler) // /api/v2/list
|
||
v2.Get("/user", handler) // /api/v2/user
|
||
|
||
// ...
|
||
}
|
||
|
||
```
|
||
|
||
### 中介器 logger
|
||
|
||
📖 [Logger](https://docs.gofiber.io/api/middleware/logger)
|
||
|
||
```go
|
||
package main
|
||
|
||
import (
|
||
"log"
|
||
|
||
"github.com/gofiber/fiber/v2"
|
||
"github.com/gofiber/fiber/v2/middleware/logger"
|
||
)
|
||
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
app.Use(logger.New())
|
||
|
||
// ...
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
```
|
||
|
||
### 跨網域資源共享 (CORS)
|
||
|
||
📖 [CORS](https://docs.gofiber.io/api/middleware/cors)
|
||
|
||
```go
|
||
import (
|
||
"log"
|
||
|
||
"github.com/gofiber/fiber/v2"
|
||
"github.com/gofiber/fiber/v2/middleware/cors"
|
||
)
|
||
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
app.Use(cors.New())
|
||
|
||
// ...
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
```
|
||
|
||
在`Origin` header 中放網域來檢查 CORS:
|
||
|
||
```bash
|
||
curl -H "Origin: http://example.com" --verbose http://localhost:3000
|
||
```
|
||
|
||
### 客制 404 回應
|
||
|
||
📖 [HTTP Methods](https://docs.gofiber.io/api/ctx#status)
|
||
|
||
```go
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
app.Static("/", "./public")
|
||
|
||
app.Get("/demo", func(c *fiber.Ctx) error {
|
||
return c.SendString("This is a demo!")
|
||
})
|
||
|
||
app.Post("/register", func(c *fiber.Ctx) error {
|
||
return c.SendString("Welcome!")
|
||
})
|
||
|
||
// Last middleware to match anything
|
||
app.Use(func(c *fiber.Ctx) error {
|
||
return c.SendStatus(404)
|
||
// => 404 "Not Found"
|
||
})
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
```
|
||
|
||
### JSON 回應
|
||
|
||
📖 [JSON](https://docs.gofiber.io/ctx#json)
|
||
|
||
```go
|
||
type User struct {
|
||
Name string `json:"name"`
|
||
Age int `json:"age"`
|
||
}
|
||
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
app.Get("/user", func(c *fiber.Ctx) error {
|
||
return c.JSON(&User{"John", 20})
|
||
// => {"name":"John", "age":20}
|
||
})
|
||
|
||
app.Get("/json", func(c *fiber.Ctx) error {
|
||
return c.JSON(fiber.Map{
|
||
"success": true,
|
||
"message": "Hi John!",
|
||
})
|
||
// => {"success":true, "message":"Hi John!"}
|
||
})
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
```
|
||
|
||
### WebSocket 升級
|
||
|
||
📖 [Websocket](https://github.com/gofiber/websocket)
|
||
|
||
```go
|
||
import (
|
||
"github.com/gofiber/fiber/v2"
|
||
"github.com/gofiber/fiber/v2/middleware/websocket"
|
||
)
|
||
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
app.Get("/ws", websocket.New(func(c *websocket.Conn) {
|
||
for {
|
||
mt, msg, err := c.ReadMessage()
|
||
if err != nil {
|
||
log.Println("read:", err)
|
||
break
|
||
}
|
||
log.Printf("recv: %s", msg)
|
||
err = c.WriteMessage(mt, msg)
|
||
if err != nil {
|
||
log.Println("write:", err)
|
||
break
|
||
}
|
||
}
|
||
}))
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
// ws://localhost:3000/ws
|
||
}
|
||
```
|
||
|
||
### Server-Sent Events
|
||
|
||
📖 [More Info](https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events)
|
||
|
||
```go
|
||
import (
|
||
"github.com/gofiber/fiber/v2"
|
||
"github.com/valyala/fasthttp"
|
||
)
|
||
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
app.Get("/sse", func(c *fiber.Ctx) error {
|
||
c.Set("Content-Type", "text/event-stream")
|
||
c.Set("Cache-Control", "no-cache")
|
||
c.Set("Connection", "keep-alive")
|
||
c.Set("Transfer-Encoding", "chunked")
|
||
|
||
c.Context().SetBodyStreamWriter(fasthttp.StreamWriter(func(w *bufio.Writer) {
|
||
fmt.Println("WRITER")
|
||
var i int
|
||
|
||
for {
|
||
i++
|
||
msg := fmt.Sprintf("%d - the time is %v", i, time.Now())
|
||
fmt.Fprintf(w, "data: Message: %s\n\n", msg)
|
||
fmt.Println(msg)
|
||
|
||
w.Flush()
|
||
time.Sleep(5 * time.Second)
|
||
}
|
||
}))
|
||
|
||
return nil
|
||
})
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
```
|
||
|
||
### Recover 中介器
|
||
|
||
📖 [Recover](https://docs.gofiber.io/api/middleware/recover)
|
||
|
||
```go
|
||
import (
|
||
"github.com/gofiber/fiber/v2"
|
||
"github.com/gofiber/fiber/recover"
|
||
)
|
||
|
||
func main() {
|
||
app := fiber.New()
|
||
|
||
app.Use(recover.New())
|
||
|
||
app.Get("/", func(c *fiber.Ctx) error {
|
||
panic("normally this would crash your app")
|
||
})
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
```
|
||
|
||
</details>
|
||
|
||
## 🧬 内部中間件
|
||
以下為包含在Fiber框架中的中間件列表.
|
||
|
||
| 中間件 | 描述 |
|
||
| :------------------------------------------------------------------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||
| [basicauth](https://github.com/gofiber/fiber/tree/master/middleware/basicauth) | 基本身份驗證中間件提供 HTTP 基本身份驗證。 它為有效憑據調用下一個處理程序,並為丟失或無效憑據調用 401 Unauthorized。 |
|
||
| [cache](https://github.com/gofiber/fiber/tree/master/middleware/cache) | 攔截和緩存響應 |
|
||
| [compress](https://github.com/gofiber/fiber/tree/master/middleware/compress) | CFiber的壓縮中間件,默認支持`deflate`、`gzip`和`brotli`。 |
|
||
| [cors](https://github.com/gofiber/fiber/tree/master/middleware/cors) | 使用各種選項啟用跨域資源共享 \(CORS\)。 |
|
||
| [csrf](https://github.com/gofiber/fiber/tree/master/middleware/csrf) | 防止 CSRF 漏洞利用。 |
|
||
| [encryptcookie](https://github.com/gofiber/fiber/tree/master/middleware/encryptcookie) | Encrypt middleware which encrypts cookie values. |
|
||
| [etag](https://github.com/gofiber/fiber/tree/master/middleware/etag) | ETag middleware that lets caches be more efficient and save bandwidth, as a web server does not need to resend a full response if the content has not changed. |
|
||
| [expvar](https://github.com/gofiber/fiber/tree/master/middleware/expvar) | Expvar middleware that serves via its HTTP server runtime exposed variants in the JSON format. |
|
||
| [favicon](https://github.com/gofiber/fiber/tree/master/middleware/favicon) | 如果提供了文件路徑,則忽略日誌中的網站圖標或從內存中提供服務。 |
|
||
| [filesystem](https://github.com/gofiber/fiber/tree/master/middleware/filesystem) | 用於 Fiber 的 FileSystem 中間件,特別感謝 Alireza Salary |
|
||
| [limiter](https://github.com/gofiber/fiber/tree/master/middleware/limiter) | Fiber 的限速中間件。 用於限制對公共 API 和/或端點的重複請求,例如密碼重置。 |
|
||
| [logger](https://github.com/gofiber/fiber/tree/master/middleware/logger) | HTTP 請求/響應 logger. |
|
||
| [monitor](https://github.com/gofiber/fiber/tree/master/middleware/monitor) | Monitor middleware that reports server metrics, inspired by express-status-monitor |
|
||
| [pprof](https://github.com/gofiber/fiber/tree/master/middleware/pprof) | 特別感謝 Matthew Lee \(@mthli\) |
|
||
| [proxy](https://github.com/gofiber/fiber/tree/master/middleware/proxy) | 允許您將請求代理到多個服務器 |
|
||
| [recover](https://github.com/gofiber/fiber/tree/master/middleware/recover) | 恢復中間件從堆棧鏈中任何地方的恐慌中恢復,並將控制權交給集中式[ ErrorHandler](https://docs.gofiber.io/guide/error-handling). |
|
||
| [requestid](https://github.com/gofiber/fiber/tree/master/middleware/requestid) | 為每個請求添加一個 requestid。 |
|
||
| [session](https://github.com/gofiber/fiber/tree/master/middleware/session) | Session middleware. NOTE: This middleware uses our Storage package. |
|
||
| [skip](https://github.com/gofiber/fiber/tree/master/middleware/skip) | Skip middleware that skips a wrapped handler is a predicate is true. |
|
||
| [timeout](https://github.com/gofiber/fiber/tree/master/middleware/timeout) | 添加請求的最大時間,如果超過則轉發給 ErrorHandler。 |
|
||
|
||
## 🧬 外部中間件
|
||
|
||
由 [Fiber 團隊] (https://github.com/orgs/gofiber/people) 維護的外部託管中間件模塊列表。
|
||
|
||
| Middleware | Description |
|
||
| :------------------------------------------------ | :------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||
| [adaptor](https://github.com/gofiber/adaptor) | net/http 處理程序與 Fiber 請求處理程序之間的轉換器,特別感謝 @arsmn! |
|
||
| [helmet](https://github.com/gofiber/helmet) | 通過設置各種 HTTP 標頭來幫助保護您的應用程序。 |
|
||
| [jwt](https://github.com/gofiber/jwt) | JWT 返回一個 JSON Web Token \(JWT\) 身份驗證中間件。 |
|
||
| [keyauth](https://github.com/gofiber/keyauth) | Key auth 中間件提供基於密鑰的身份驗證。 |
|
||
| [redirect](https://github.com/gofiber/redirect) | Redirect middleware |
|
||
| [rewrite](https://github.com/gofiber/rewrite) | 重寫中間件根據提供的規則重寫 URL 路徑。 它有助於向後兼容或只是創建更清晰和更具描述性的鏈接。 |
|
||
| [storage](https://github.com/gofiber/storage) | Premade storage drivers that implement the Storage interface, designed to be used with various Fiber middlewares. |
|
||
| [template](https://github.com/gofiber/template) |該軟件包包含 8 個模板引擎,可用於 Fiber `v1.10.x` Go 版本 1.13 或更高版本。 |
|
||
| [websocket](https://github.com/gofiber/websocket) | 基於 Fasthttp WebSocket for Fiber,支持 Locals! |
|
||
|
||
## 🕶️ Awesome List
|
||
|
||
For more articles, middlewares, examples or tools check our [awesome list](https://github.com/gofiber/awesome-fiber).
|
||
|
||
## 👍 貢獻
|
||
|
||
如果您要說聲**謝謝**或支援`Fiber`的積極發展:
|
||
|
||
1. 點擊[GitHub Star](https://github.com/gofiber/fiber/stargazers)關注本專案。
|
||
2. 在[Twitter](https://twitter.com/intent/tweet?text=Fiber%20is%20an%20Express%20inspired%20%23web%20%23framework%20built%20on%20top%20of%20Fasthttp%2C%20the%20fastest%20HTTP%20engine%20for%20%23Go.%20Designed%20to%20ease%20things%20up%20for%20%23fast%20development%20with%20zero%20memory%20allocation%20and%20%23performance%20in%20mind%20%F0%9F%9A%80%20https%3A%2F%2Fgithub.com%2Fgofiber%2Ffiber)轉[推](https://twitter.com/intent/tweet?text=Fiber%20is%20an%20Express%20inspired%20%23web%20%23framework%20built%20on%20top%20of%20Fasthttp%2C%20the%20fastest%20HTTP%20engine%20for%20%23Go.%20Designed%20to%20ease%20things%20up%20for%20%23fast%20development%20with%20zero%20memory%20allocation%20and%20%23performance%20in%20mind%20%F0%9F%9A%80%20https%3A%2F%2Fgithub.com%2Fgofiber%2Ffiber)。
|
||
3. 在[Medium](https://medium.com/)、[Dev.to](https://dev.to/)、部落格上發表意見或教學。
|
||
4. 贊助我們[一杯咖啡](https://buymeacoff.ee/fenny)。
|
||
|
||
## ☕ 支持者
|
||
|
||
Fiber 是一個以贊助維生的開源專案,像是: 網域、gitbook、netlify、serverless 伺服器。如果你想贊助也可以 ☕ [**買杯咖啡**](https://buymeacoff.ee/fenny)
|
||
|
||
| | User | Donation |
|
||
| :--------------------------------------------------------- | :----------------------------------------------- | :------- |
|
||
|  | [@destari](https://github.com/destari) | ☕ x 10 |
|
||
|  | [@dembygenesis](https://github.com/dembygenesis) | ☕ x 5 |
|
||
|  | [@thomasvvugt](https://github.com/thomasvvugt) | ☕ x 5 |
|
||
|  | [@hendratommy](https://github.com/hendratommy) | ☕ x 5 |
|
||
|  | [@ekaputra07](https://github.com/ekaputra07) | ☕ x 5 |
|
||
|  | [@jorgefuertes](https://github.com/jorgefuertes) | ☕ x 5 |
|
||
|  | [@candidosales](https://github.com/candidosales) | ☕ x 5 |
|
||
|  | [@l0nax](https://github.com/l0nax) | ☕ x 3 |
|
||
|  | [@bihe](https://github.com/bihe) | ☕ x 3 |
|
||
|  | [@justdave](https://github.com/justdave) | ☕ x 3 |
|
||
|  | [@koddr](https://github.com/koddr) | ☕ x 1 |
|
||
|  | [@lapolinar](https://github.com/lapolinar) | ☕ x 1 |
|
||
|  | [@diegowifi](https://github.com/diegowifi) | ☕ x 1 |
|
||
|  | [@ssimk0](https://github.com/ssimk0) | ☕ x 1 |
|
||
|  | [@raymayemir](https://github.com/raymayemir) | ☕ x 1 |
|
||
|  | [@melkorm](https://github.com/melkorm) | ☕ x 1 |
|
||
|  | [@marvinjwendt](https://github.com/thomasvvugt) | ☕ x 1 |
|
||
|  | [@toishy](https://github.com/toishy) | ☕ x 1 |
|
||
|
||
## 💻 貢獻者
|
||
|
||
<img src="https://opencollective.com/fiber/contributors.svg?width=890&button=false" alt="Code Contributors" style="max-width:100%;">
|
||
|
||
## ⭐️ Stargazers
|
||
|
||
<img src="https://starchart.cc/gofiber/fiber.svg" alt="Stargazers over time" style="max-width: 100%">
|
||
|
||
## ⚠️ 授權
|
||
|
||
版權所有 (c) 2019 年至今 [Fenny](https://github.com/fenny) 和 [貢獻者](https://github.com/gofiber/fiber/graphs/contributors)。 `Fiber` 是根據 [MIT 許可證] (https://github.com/gofiber/fiber/blob/master/LICENSE) 許可的免費開源軟件。 官方徽標由 [Vic Shóstak](https://github.com/koddr) 創建並在 [Creative Commons](https://creativecommons.org/licenses/by-sa/4.0/) 許可下分發 (CC BY- SA 4.0 國際)。
|
||
|
||
**Third-party library licenses**
|
||
|
||
- [schema](https://github.com/gorilla/schema/blob/master/LICENSE)
|
||
- [isatty](https://github.com/mattn/go-isatty/blob/master/LICENSE)
|
||
- [fasthttp](https://github.com/valyala/fasthttp/blob/master/LICENSE)
|
||
- [colorable](https://github.com/mattn/go-colorable/blob/master/LICENSE)
|
||
- [fasttemplate](https://github.com/valyala/fasttemplate/blob/master/LICENSE)
|
||
- [bytebufferpool](https://github.com/valyala/bytebufferpool/blob/master/LICENSE)
|
||
- [gopsutil](https://github.com/shirou/gopsutil/blob/master/LICENSE)
|
||
- [go-ole](https://github.com/go-ole/go-ole)
|
||
- [wmi](https://github.com/StackExchange/wmi)
|
||
- [dictpool](https://github.com/savsgio/dictpool)
|