mirror of https://github.com/gofiber/fiber.git
862 lines
51 KiB
Markdown
862 lines
51 KiB
Markdown
<p align="center">
|
||
<a href="https://gofiber.io">
|
||
|
||
<picture>
|
||
<source height="125" media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/gofiber/docs/master/static/img/logo-dark.svg">
|
||
<img height="125" alt="Fiber" src="https://raw.githubusercontent.com/gofiber/docs/master/static/img/logo.svg">
|
||
</picture>
|
||
|
||
</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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&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-square&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_uk.md">
|
||
<img height="20px" src="https://img.shields.io/badge/UK-flag.svg?color=555555&style=flat-square&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_az.md">
|
||
<img height="20px" src="https://img.shields.io/badge/AZ-flag.svg?color=555555&style=flat-square&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_eg.md">
|
||
<img height="20px" src="https://img.shields.io/badge/EG-flag.svg?color=555555&style=flat-square&logo=">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/blob/master/.github/README_pl.md">
|
||
<img height="20px" src="https://img.shields.io/badge/PL-flag.svg?color=555555&style=flat-square&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-square">
|
||
</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?style=flat-square">
|
||
</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-square">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/actions?query=workflow%3ASecurity">
|
||
<img src="https://img.shields.io/github/actions/workflow/status/gofiber/fiber/security.yml?branch=master&label=%F0%9F%94%91%20gosec&style=flat-square&color=75C46B">
|
||
</a>
|
||
<a href="https://github.com/gofiber/fiber/actions?query=workflow%3ATest">
|
||
<img src="https://img.shields.io/github/actions/workflow/status/gofiber/fiber/test.yml?branch=master&label=%F0%9F%A7%AA%20tests&style=flat-square&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-square">
|
||
</a>
|
||
<a href="https://gofiber.io/discord">
|
||
<img src="https://img.shields.io/discord/704680098577514527?style=flat-square&label=%F0%9F%92%AC%20discord&color=00ACD7">
|
||
</a>
|
||
</p>
|
||
<br>
|
||
<p align="center">
|
||
<div dir="rtl">
|
||
<b>Fiber</b> الهام گرفته از <b>فریمورک وب</b> <a href="https://github.com/expressjs/express">Express</a> است که برپایه <a href="https://github.com/valyala/fasthttp">Fasthttp</a> ساخته شده است, که سریعترین موتور HTTP برای زبان <a href="https://go.dev/doc/">Go</a> است. طراحی شده است تا با تخصیص حافظه و عملکرد صفر ، کارها را برای توسعه سریع آسان کند.
|
||
<div dir="rtl"><br>
|
||
</p>
|
||
|
||
## ⚡️ شروع سریع
|
||
|
||
<div dir="ltr">
|
||
<br>
|
||
|
||
```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")
|
||
}
|
||
```
|
||
|
||
</div>
|
||
</br>
|
||
|
||
## 🤖 بنچمارک
|
||
|
||
<br>
|
||
<p align="center">
|
||
<div dir="rtl">
|
||
این تست ها توسط <a href="https://www.techempower.com/benchmarks/#section=data-r19&hw=ph&test=plaintext">TechEmpower</a> و <a href="https://github.com/smallnest/go-web-framework-benchmark">Go Web</a> انجام شده است. اگر شما تمامی نتایج را می خواهید ببینید, لطفا صفحه <a href="https://docs.gofiber.io/extra/benchmarks">ویکی</a> ما را بازدید کنید.
|
||
<div dir="rtl">
|
||
<br>
|
||
</p>
|
||
|
||
<p float="left" align="middle">
|
||
<img src="https://raw.githubusercontent.com/gofiber/docs/master/static/img/benchmark-pipeline.png" width="49%">
|
||
<img src="https://raw.githubusercontent.com/gofiber/docs/master/static/img/benchmark_alloc.png" width="49%">
|
||
</p>
|
||
</br>
|
||
|
||
## ⚙️ نصب و راه اندازی
|
||
|
||
<br>
|
||
<p align="center">
|
||
<div dir="rtl">
|
||
مطمئن شوید Go را نصب (<a href="https://go.dev/dl/">دانلود</a>) کرده اید. نسخه 1.17 یا بیشتر مورد نیاز است.<br>
|
||
پروژه خود را با ساختن یک پوشه و سپس اجرای <code>go mod init github.com/your/repo</code> داخل پوشه (<a href="https://go.dev/blog/using-go-modules">یادگیری بیشتر</a>) راه اندازی کنید. سپس Fiber را با دستور <code><a href="https://pkg.go.dev/cmd/go/#hdr-Add_dependencies_to_current_module_and_install_them">go get</a></code> نصب کنید :
|
||
<div dir="rtl">
|
||
<br>
|
||
</p>
|
||
|
||
<div dir="ltr">
|
||
|
||
```bash
|
||
go get -u github.com/gofiber/fiber/v2
|
||
```
|
||
|
||
</div>
|
||
|
||
</br>
|
||
|
||
## 🎯 ویژگی ها
|
||
|
||
</br>
|
||
|
||
- [مسیریابی](https://docs.gofiber.io/guide/routing) قدرتمند
|
||
- Serve [پرونده های ثابت](https://docs.gofiber.io/api/app#static)
|
||
- حداکثر [عملکرد](https://docs.gofiber.io/extra/benchmarks)
|
||
- مصرف [حافظه کم](https://docs.gofiber.io/extra/benchmarks)
|
||
- قابلیت [API endpoints](https://docs.gofiber.io/api/ctx)
|
||
- پشتیبانی از [Middleware](https://docs.gofiber.io/category/-middleware) & [Next](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)
|
||
- دارای [Template engines](https://github.com/gofiber/template) اختصاصی
|
||
- [پشتیبانی از وب سوکت](https://github.com/gofiber/websocket)
|
||
- [Server-Sent events](https://github.com/gofiber/recipes/tree/master/sse)
|
||
- قابلیت [Rate Limiter](https://docs.gofiber.io/api/middleware/limiter)
|
||
- ترجمه در [19 زبان](https://docs.gofiber.io/)
|
||
- و امکانات بیشتر, [دیدن در داکیومنت](https://docs.gofiber.io/)
|
||
|
||
</br>
|
||
|
||
## 💡 فلسفه
|
||
|
||
<br>
|
||
<p align="center">
|
||
<div dir="rtl">
|
||
گوفر های جدیدی که از <a href="https://nodejs.org/en/about/">Node.js</a> به <a href="https://go.dev/doc/">Go</a> تغییر می دهند قبل از شروع ساخت برنامه های وب یا میکروسرویس ها با یک منحنی یادگیری رو به رو هستند. Fiber, یک <b>فریمورک وب</b> است و با ایده <b>مینیمالیسم</b> ایجاد شده است و <b>روش های unix</b> را دنبال می کند, بنابرین با استقبال گرم و اعتماد کامل وارد دنیای Go شده است.<br>
|
||
|
||
Fiber از Express <b>الهام گرفته</b>, که محبوب ترین فریمورک وب روی اینترنت است. ما <b>سادگی</b> Express را با <b>عملکرد بالا</b> زبان Go ترکیب کردیم. اگر شما قبلا یک برنامه وب را در Node.js (با استفاده از Express یا موارد مشابه) پیاده سازی کرده اید. بسیاری از روش ها و اصول ها برای شما ساده به نظر خواهد رسید.<br>
|
||
|
||
ما در مورد <a href="https://github.com/gofiber/fiber/issues">مشکلات</a> کاربران, <a href="https://gofiber.io/discord">کانال</a> Discord سراسر دنیا گوش می دهیم و تا بتوانیم یک وب فریم ورک <b>سریع, مطمئن, ساده</b> ایجاد کنیم. درست مثل Express برای برنامه نویس های جاوا اسکریپت.
|
||
|
||
<div dir="rtl">
|
||
<br>
|
||
</p>
|
||
|
||
## ⚠️ محدودیت ها
|
||
|
||
- به دلیل استفاده ناامن از Fiber, ممکن است کتابخانه همیشه با آخرین نسخه Go سازگار نباشد. Fiber 2.40.0 با زبان گو نسخه 1.17 تا 1.21 تست شده است.
|
||
- فریمورک Fiber با پکیج net/http سازگار نیست. این بدان معناست شما نمی توانید از پکیج های مانند go-swagger, gqlgen یا سایر پروژه هایی که بخشی از اکوسیستم net/http هستند استفاده کنید.
|
||
|
||
<br>
|
||
|
||
## 👀 مثال ها
|
||
|
||
<p align="center">
|
||
<div dir="rtl">
|
||
در پایین تعدادی نمونه مثال هستش. اگر شما مثال های بیشتر می خواهید ببینید, لطفا <a href="https://github.com/gofiber/recipes">مخزن کد</a> و <a href="https://docs.gofiber.io/">داکیومنت های</a> ما را بازدید کنید.
|
||
<div dir="rtl">
|
||
<br>
|
||
</p>
|
||
|
||
#### 📖 [**Basic Routing**](https://docs.gofiber.io/#basic-routing)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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"))
|
||
}
|
||
|
||
```
|
||
|
||
</div>
|
||
|
||
<div dir="ltr" >
|
||
|
||
#### 📖 [**Route Naming**](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"))
|
||
}
|
||
|
||
```
|
||
|
||
</div>
|
||
|
||
#### 📖 [**Serving Static Files**](https://docs.gofiber.io/api/app#static)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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"))
|
||
}
|
||
|
||
```
|
||
|
||
</div>
|
||
|
||
#### 📖 [**Middleware & Next**](https://docs.gofiber.io/api/ctx#next)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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/list
|
||
app.Get("/api/list", func(c *fiber.Ctx) error {
|
||
fmt.Println("🥉 Last handler")
|
||
return c.SendString("Hello, World 👋!")
|
||
})
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
|
||
```
|
||
|
||
</div>
|
||
</br>
|
||
|
||
<details>
|
||
<summary>📚 نمایش نمونه کدهای بیشتر</summary>
|
||
</br>
|
||
|
||
### View engines
|
||
|
||
</br>
|
||
|
||
📖 [پیکربندی](https://docs.gofiber.io/api/fiber#config)
|
||
📖 [موتورها](https://github.com/gofiber/template)
|
||
📖 [رندر](https://docs.gofiber.io/api/ctx#render)
|
||
|
||
<br>
|
||
<p align="center">
|
||
<div dir="rtl">
|
||
Fiber زمانیکه view engine تنظیم نشده باشد بطور پیش فرض از <a href="https://pkg.go.dev/html/template/">html/template</a> استفاده می کند.<br>
|
||
شما می توانید از موتورهای مختلفی نظیر <a href="https://github.com/eknkc/amber">amber</a>, <a href="https://github.com/aymerick/raymond">handlebars</a>, <a href="https://github.com/cbroglie/mustache">mustache</a> یا <a href="https://github.com/Joker/jade">pug</a> استفاده کنید.<br>
|
||
پکیج موتورهای پشتیبانی شده را می توانید در <a href="https://github.com/gofiber/template">اینجا</a> ببینید.
|
||
<div dir="rtl">
|
||
<br>
|
||
</p>
|
||
|
||
<div dir="ltr">
|
||
|
||
```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"))
|
||
}
|
||
```
|
||
|
||
</div>
|
||
|
||
### Grouping routes into chains
|
||
|
||
📖 [Group](https://docs.gofiber.io/api/app#group)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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
|
||
|
||
// ...
|
||
}
|
||
|
||
```
|
||
|
||
</div>
|
||
|
||
### Middleware logger
|
||
|
||
📖 [Logger](https://docs.gofiber.io/api/middleware/logger)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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"))
|
||
}
|
||
```
|
||
|
||
</div>
|
||
|
||
### Cross-Origin Resource Sharing (CORS)
|
||
|
||
📖 [CORS](https://docs.gofiber.io/api/middleware/cors)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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"))
|
||
}
|
||
```
|
||
|
||
</div>
|
||
|
||
Check CORS by passing any domain in `Origin` header:
|
||
|
||
<div dir="ltr">
|
||
|
||
```bash
|
||
curl -H "Origin: http://example.com" --verbose http://localhost:3000
|
||
```
|
||
|
||
</div>
|
||
|
||
### Custom 404 response
|
||
|
||
📖 [HTTP Methods](https://docs.gofiber.io/api/ctx#status)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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"))
|
||
}
|
||
```
|
||
|
||
</div>
|
||
|
||
### JSON Response
|
||
|
||
📖 [JSON](https://docs.gofiber.io/api/ctx#json)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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"))
|
||
}
|
||
```
|
||
|
||
</div>
|
||
|
||
### WebSocket Upgrade
|
||
|
||
📖 [Websocket](https://github.com/gofiber/websocket)
|
||
|
||
<div dir="ltr">
|
||
|
||
```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"))
|
||
}
|
||
```
|
||
|
||
</div>
|
||
|
||
### Recover middleware
|
||
|
||
📖 [Recover](https://docs.gofiber.io/api/middleware/recover)
|
||
|
||
<div dir="ltr">
|
||
|
||
```go
|
||
import (
|
||
"github.com/gofiber/fiber/v2"
|
||
"github.com/gofiber/fiber/v2/middleware/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"))
|
||
}
|
||
```
|
||
|
||
### Using Trusted Proxy
|
||
|
||
📖 [Config](https://docs.gofiber.io/api/fiber#config)
|
||
|
||
```go
|
||
import (
|
||
"github.com/gofiber/fiber/v2"
|
||
"github.com/gofiber/fiber/v2/middleware/recover"
|
||
)
|
||
|
||
func main() {
|
||
app := fiber.New(fiber.Config{
|
||
EnableTrustedProxyCheck: true,
|
||
TrustedProxies: []string{"0.0.0.0", "1.1.1.1/30"}, // IP address or IP address range
|
||
ProxyHeader: fiber.HeaderXForwardedFor,
|
||
})
|
||
|
||
// ...
|
||
|
||
log.Fatal(app.Listen(":3000"))
|
||
}
|
||
```
|
||
|
||
</div>
|
||
|
||
</details>
|
||
</br></br>
|
||
|
||
## 🧬 Middleware داخلی
|
||
|
||
</br>
|
||
|
||
در اینجا لیستی از middleware های Fiber موجود است.
|
||
|
||
</br>
|
||
|
||
<div dir="rtl">
|
||
|
||
| Middleware | توضیحات |
|
||
| :------------------------------------------------------------------------------------- | :--------------------------------------------------------------------------------------------------------------------------------------------------------------- | --- |
|
||
| [basicauth](https://github.com/gofiber/fiber/tree/master/middleware/basicauth) | یک میدلور پایه که سیستم احراز هویت پایه ای را فراهم میکند. در صورت معتبر بودن درخواست روتر بعدی صدا زده شده و در صورت نامعتبر بودن خطای ۴۰۱ نمایش داده میشود. |
|
||
| [cache](https://github.com/gofiber/fiber/tree/master/middleware/cache) | پاسخ هارا رهگیری کرده و انها را به صورت موقت ذخیره میکند. |
|
||
| [compress](https://github.com/gofiber/fiber/tree/master/middleware/compress) | یک میدلور فشرده سازی برای Fiber که به طور پیشفرض از `deflate`, `gzip` و `brotli`. پشتیبانی میکند. | |
|
||
| [cors](https://github.com/gofiber/fiber/tree/master/middleware/cors) | فعال سازی هدر های cross-origin با گزینه های مختلف. |
|
||
| [csrf](https://github.com/gofiber/fiber/tree/master/middleware/csrf) | در برابر حملات CSRF ایمنی ایجاد میکند. |
|
||
| [encryptcookie](https://github.com/gofiber/fiber/tree/master/middleware/encryptcookie) | مقادیر کوکی هارا رمزنگاری میکند. |
|
||
| [envvar](https://github.com/gofiber/fiber/tree/master/middleware/envvar) | با ارائه تنظیمات اختیاری، متغیرهای محیط را در معرض دید قرار دهید. |
|
||
| [etag](https://github.com/gofiber/fiber/tree/master/middleware/etag) | میدلور ETag به کش ها اجازه میدهد کارآمد تر عمل کرده و در پهنای باند صرفه جویی کنند. به عنوان یک وب سرور نیازی به دادن پاسخ کامل نیست اگر محتوا تغییر نکرده باشد. |
|
||
| [expvar](https://github.com/gofiber/fiber/tree/master/middleware/expvar) | میدلور Expvar میتواند متغیر هایی را تعریف کرده و مقادیر انها را در زمان اجرا با فرمت JSON به شما نشان دهد. |
|
||
| [favicon](https://github.com/gofiber/fiber/tree/master/middleware/favicon) | جلوگیری و یا کش کردن درخواست های favicon در صورتی که مسیر یک فایل را داده باشید. |
|
||
| [filesystem](https://github.com/gofiber/fiber/tree/master/middleware/filesystem) | میدلور FileSystem به شما اجازه میدهد فایل های یک مسیر را عمومی کنید. |
|
||
| [limiter](https://github.com/gofiber/fiber/tree/master/middleware/limiter) | میدلور محدود کننده تعداد درخواست برای Fiber. |
|
||
| [logger](https://github.com/gofiber/fiber/tree/master/middleware/logger) | لاگ گرفتن از درخواست و پاسخ های HTTP. |
|
||
| [monitor](https://github.com/gofiber/fiber/tree/master/middleware/monitor) | وضعیت سرور را مانیتور و گزارش میکند، از 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) | خطا های زمان اجرا را در وب سرور HTTP شما مدیریت میکنند[ ErrorHandler](https://docs.gofiber.io/guide/error-handling). |
|
||
| [requestid](https://github.com/gofiber/fiber/tree/master/middleware/requestid) | به تمامی درخواست ها شناسه ای را اختصاص میدهد. |
|
||
| [session](https://github.com/gofiber/fiber/tree/master/middleware/session) | برای ذخیره و مدیریت شناسه کاربری یا session بازدید کنندگان استفاده .میشود |
|
||
| [skip](https://github.com/gofiber/fiber/tree/master/middleware/skip) | این میدلور میتواند با استفاده از شرط های تعیین شده درخواست هایی را نادیده بگیرد. |
|
||
| [timeout](https://github.com/gofiber/fiber/tree/master/middleware/timeout) | این میدلور محدودیت زمانی ای را برای درخواست ها تنظیم میکند، در صورتی که محدودیت به پایان برسد ErrorHandler صدا زده میشود. |
|
||
| [keyauth](https://github.com/gofiber/keyauth) | این میدلور احراز هویت مبتنی بر کلید را فراهم می کند. |
|
||
| [redirect](https://github.com/gofiber/redirect) | برای ریدایرکت کردن از این میدلور میتوانید استفاده کنید. |
|
||
| [rewrite](https://github.com/gofiber/rewrite) | مسیر URL را براساس قوانین مشخص شده بازنویسی می کند. این میتواند برای سازگاری با ورژن های قبلی یا برای ساخت لینک های تمیز تر و توصیفی تر مفید باشد. |
|
||
| [adaptor](https://github.com/gofiber/adaptor) | Converter for net/http handlers to/from Fiber request handlers, special thanks to @arsmn! |
|
||
| [helmet](https://github.com/gofiber/helmet) | با استفاده از HTTP هدر های مختلف به ایمن سازی برنامه شما کمک می کند. |
|
||
|
||
</div>
|
||
</br></br>
|
||
|
||
## 🧬 Middleware خارجی
|
||
|
||
</br>
|
||
|
||
لیست middleware های خارجی که توسط [تیم Fiber](https://github.com/orgs/gofiber/people) نگه داری می شود.
|
||
|
||
</br>
|
||
|
||
<div dir="ltr">
|
||
|
||
| Middleware | توضیحات |
|
||
| :------------------------------------------------ | :-------------------------------------------------------------------------------------------------------------------- |
|
||
| [jwt](https://github.com/gofiber/jwt) | JWT returns a JSON Web Token \(JWT\) auth middleware. |
|
||
| [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) | This package contains 8 template engines that can be used with Fiber `v1.10.x` Go version 1.13 or higher is required. |
|
||
| [websocket](https://github.com/gofiber/websocket) | Based on Fasthttp WebSocket for Fiber with Locals support! |
|
||
|
||
## 🕶️ Awesome List
|
||
|
||
[awesome list](https://github.com/gofiber/awesome-fiber) برای مقاله، میدلور، مثال ها و ابزار های بیشتر لطفا از این لینک بازدید کنید
|
||
|
||
</br>
|
||
|
||
## 👍 مشارکت کنندگان
|
||
|
||
</br>
|
||
|
||
اگر شما میخواهید **تشکر** کنید و یا از توسعه فعال Fiber حمایت کنید :
|
||
|
||
1. یک [GitHub Star](https://github.com/gofiber/fiber/stargazers) به پروژه اضافه کنید.
|
||
2. ارسال توییت درباره Fiber برروی [صفحه توییتر شما](https://x.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).
|
||
|
||
</br>
|
||
|
||
## ☕ حامیان مالی
|
||
|
||
</br>
|
||
|
||
Fiber یک پروژه متن باز است که با کمک مالی برای پرداخت قبض های دامنه, gitbook, netlify, هاست انجام می شود. اگر می خواهید از Fiber حمایت کنید شما می توانید [**از اینجا یک قهوه بخرید**](https://buymeacoff.ee/fenny).
|
||
|
||
</br>
|
||
|
||
| | کاربر | حمایت مالی |
|
||
| :--------------------------------------------------------- | :----------------------------------------------- | :--------- |
|
||
|  | [@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/marvinjwendt) | ☕ x 1 |
|
||
|  | [@toishy](https://github.com/toishy) | ☕ x 1 |
|
||
|
||
</br>
|
||
|
||
## 💻 مشارکت کنندگان کد
|
||
|
||
</br>
|
||
|
||
<img src="https://opencollective.com/fiber/contributors.svg?width=890&button=false" alt="Code Contributors" style="max-width:100%;">
|
||
|
||
</br>
|
||
|
||
## ⭐️ ستاره ها
|
||
|
||
</br>
|
||
|
||
<img src="https://starchart.cc/gofiber/fiber.svg" alt="Stargazers over time" style="max-width: 100%">
|
||
|
||
</br></br>
|
||
|
||
## ⚠️ لایسنس
|
||
|
||
</br>
|
||
|
||
<div dir="ltr">
|
||
|
||
Copyright (c) 2019-present [Fenny](https://github.com/fenny) and [Contributors](https://github.com/gofiber/fiber/graphs/contributors). `Fiber` is free and open-source software licensed under the [MIT License](https://github.com/gofiber/fiber/blob/master/LICENSE). Official logo was created by [Vic Shóstak](https://github.com/koddr) and distributed under [Creative Commons](https://creativecommons.org/licenses/by-sa/4.0/) license (CC BY-SA 4.0 International).
|
||
|
||
</div>
|
||
|
||
</br>
|
||
|
||
**مجوزهای کتابخانه شخص ثالث**
|
||
|
||
- [colorable](https://github.com/mattn/go-colorable/blob/master/LICENSE)
|
||
- [isatty](https://github.com/mattn/go-isatty/blob/master/LICENSE)
|
||
- [runewidth](https://github.com/mattn/go-runewidth/blob/master/LICENSE)
|
||
- [fasthttp](https://github.com/valyala/fasthttp/blob/master/LICENSE)
|
||
- [bytebufferpool](https://github.com/valyala/bytebufferpool/blob/master/LICENSE)
|
||
- [fwd](https://github.com/philhofer/fwd/blob/master/LICENSE.md)
|
||
- [go-ole](https://github.com/go-ole/go-ole/blob/master/LICENSE)
|
||
- [gopsutil](https://github.com/shirou/gopsutil/blob/master/LICENSE)
|
||
- [msgp](https://github.com/tinylib/msgp/blob/master/LICENSE)
|
||
- [schema](https://github.com/gorilla/schema/blob/master/LICENSE)
|
||
- [uuid](https://github.com/google/uuid/blob/master/LICENSE)
|
||
- [wmi](https://github.com/StackExchange/wmi/blob/master/LICENSE)
|