github.com/boomhut/fiber/v2@v2.0.0-20230603160335-b65c856e57d3/.github/README_zh-TW.md (about)

     1  <p align="center">
     2    <a href="https://gofiber.io">
     3    
     4    <picture>
     5      <source height="125" media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/gofiber/docs/master/static/img/logo-dark.svg">
     6      <img height="125" alt="Fiber" src="https://raw.githubusercontent.com/gofiber/docs/master/static/img/logo.svg">
     7    </picture>
     8    
     9    </a>
    10    <br>
    11    <!-- base64 flags are available at https://www.phoca.cz/cssflags/ -->
    12     <a href="https://github.com/gofiber/fiber/blob/master/.github/README.md">
    13      <img height="20px" src="https://img.shields.io/badge/EN-flag.svg?color=555555&style=flat-square&logo=">
    14    </a>
    15    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_ru.md">
    16      <img height="20px" src="https://img.shields.io/badge/RU-flag.svg?color=555555&style=flat-square&logo=">
    17    </a>
    18    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_es.md">
    19      <img height="20px" src="https://img.shields.io/badge/ES-flag.svg?color=555555&style=flat-square&logo=">
    20    </a>
    21    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_ja.md">
    22      <img height="20px" src="https://img.shields.io/badge/JA-flag.svg?color=555555&style=flat-square&logo=">
    23    </a>
    24    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_pt.md">
    25      <img height="20px" src="https://img.shields.io/badge/PT-flag.svg?color=555555&style=flat-square&logo=">
    26    </a>
    27    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_zh-CN.md">
    28      <img height="20px" src="https://img.shields.io/badge/CN-flag.svg?color=555555&style=flat-square&logo=">
    29    </a>
    30    <!-- <a href="https://github.com/gofiber/fiber/blob/master/.github/README_zh-TW.md">
    31      <img height="20px" src="https://img.shields.io/badge/TW-flag.svg?color=555555&style=flat-square&logo=">
    32    </a> -->
    33    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_de.md">
    34      <img height="20px" src="https://img.shields.io/badge/DE-flag.svg?color=555555&style=flat-square&logo=">
    35    </a>
    36    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_nl.md">
    37      <img height="20px" src="https://img.shields.io/badge/NL-flag.svg?color=555555&style=flat-square&logo=">
    38    </a>
    39    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_ko.md">
    40      <img height="20px" src="https://img.shields.io/badge/KO-flag.svg?color=555555&style=flat-square&logo=">
    41    </a>
    42    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_fr.md">
    43      <img height="20px" src="https://img.shields.io/badge/FR-flag.svg?color=555555&style=flat-square&logo=">
    44    </a>
    45    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_tr.md">
    46      <img height="20px" src="https://img.shields.io/badge/TR-flag.svg?color=555555&style=flat-square&logo=">
    47    </a>
    48    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_id.md">
    49      <img height="20px" src="https://img.shields.io/badge/ID-flag.svg?color=555555&style=flat-square&logo=">
    50    </a>
    51    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_he.md">
    52      <img height="20px" src="https://img.shields.io/badge/HE-flag.svg?color=555555&style=flat-square&logo=">
    53    </a>
    54     <a href="https://github.com/gofiber/fiber/blob/master/.github/README_sa.md">
    55       <img height="20px" src="https://img.shields.io/badge/SA-flag.svg?color=555555&style=flat-square&logo=">
    56     </a>
    57           <a href="https://github.com/gofiber/fiber/blob/master/.github/README_fa.md">
    58       <img height="20px" src="https://img.shields.io/badge/IR-flag.svg?color=555555&style=flat-square&logo=">
    59     </a>
    60    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_it.md">
    61      <img height="20px" src="https://img.shields.io/badge/IT-flag.svg?color=555555&style=flat-square&logo=">
    62    </a>
    63    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_ckb.md">
    64      <img height="20px" src="https://img.shields.io/badge/CKB-flag.svg?color=555555&style=flat-square&logo=">
    65    </a>
    66    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_uk.md">
    67      <img height="20px" src="https://img.shields.io/badge/UK-flag.svg?color=555555&style=flat-square&logo=">
    68    </a>
    69    <a href="https://github.com/gofiber/fiber/blob/master/.github/README_az.md">
    70      <img height="20px" src="https://img.shields.io/badge/AZ-flag.svg?color=555555&style=flat-square&logo=">
    71    </a>
    72    <br>
    73    <a href="https://pkg.go.dev/github.com/gofiber/fiber/v2#pkg-overview">
    74      <img src="https://img.shields.io/badge/%F0%9F%93%9A%20godoc-pkg-00ACD7.svg?color=00ACD7&style=flat-square">
    75    </a>
    76    <a href="https://goreportcard.com/report/github.com/gofiber/fiber/v2">
    77      <img src="https://img.shields.io/badge/%F0%9F%93%9D%20goreport-A%2B-75C46B?style=flat-square">
    78    </a>
    79    <a href="https://gocover.io/github.com/gofiber/fiber">
    80      <img src="https://img.shields.io/badge/%F0%9F%94%8E%20gocover-97.8%25-75C46B.svg?style=flat-square">
    81    </a>
    82    <a href="https://github.com/gofiber/fiber/actions?query=workflow%3ASecurity">
    83      <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">
    84    </a>
    85    <a href="https://github.com/gofiber/fiber/actions?query=workflow%3ATest">
    86      <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">
    87    </a>
    88      <a href="https://docs.gofiber.io">
    89      <img src="https://img.shields.io/badge/%F0%9F%92%A1%20fiber-docs-00ACD7.svg?style=flat-square">
    90    </a>
    91    <a href="https://gofiber.io/discord">
    92      <img src="https://img.shields.io/discord/704680098577514527?style=flat-square&label=%F0%9F%92%AC%20discord&color=00ACD7">
    93    </a>
    94  
    95  </p>
    96  <p align="center">
    97    <b>Fiber</b> 是款啟發自 <a href="https://github.com/expressjs/express">Express</a> 的 <b>Web 框架</b>,建基於 <a href="https://github.com/valyala/fasthttp">Fasthttp</a>——<a href="https://go.dev/doc/">Go</a> 上<b>最快的</b> HTTP 引擎。設計旨在 <b>減輕</b> 快速開發的負擔,兼顧 <b>零記憶體分配</b> 和 <b>效能</b>。
    98  </p>
    99  
   100  ## ⚡️ 快速入門
   101  
   102  ```go
   103  package main
   104  
   105  import "github.com/boomhut/fiber/v2"
   106  
   107  func main() {
   108      app := fiber.New()
   109  
   110      app.Get("/", func(c *fiber.Ctx) error {
   111          return c.SendString("Hello, World 👋!")
   112      })
   113  
   114      app.Listen(":3000")
   115  }
   116  ```
   117  
   118  ## 🤖 效能評定結果
   119  
   120  這些測試由 [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) 資訊。
   121  
   122  <p float="left" align="middle">
   123    <img src="https://raw.githubusercontent.com/gofiber/docs/master/static/img/benchmark-pipeline.png" width="49%">
   124    <img src="https://raw.githubusercontent.com/gofiber/docs/master/static/img/benchmark_alloc.png" width="49%">
   125  </p>
   126  
   127  ## ⚙️ 安裝
   128  
   129  先確定您已經安裝 `1.17` 或更新版本的 Go([點此下載](https://go.dev/dl/))。
   130  
   131  要初始化專案,首先建立檔案夾,然後在檔案夾中執行 `go mod init github.com/名稱/儲存庫`([深入了解](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:
   132  
   133  ```bash
   134  go get -u github.com/gofiber/fiber/v2
   135  ```
   136  
   137  ## 🎯 特色
   138  
   139  -   強固的[路由系統](https://docs.gofiber.io/guide/routing)
   140  -   可以寄存[靜態檔案](https://docs.gofiber.io/api/app#static)
   141  -   疾速[效能](https://docs.gofiber.io/extra/benchmarks)
   142  -   相當低的[記憶體使用量](https://docs.gofiber.io/extra/benchmarks)
   143  -   [API 端點](https://docs.gofiber.io/api/ctx)
   144  -   支援 [中介模組](https://docs.gofiber.io/category/-middleware) 和 [接續函式 (Next)](https://docs.gofiber.io/api/ctx#next)
   145  -   [迅速開發](https://dev.to/koddr/welcome-to-fiber-an-express-js-styled-fastest-web-framework-written-with-on-golang-497) 伺服器端服務
   146  -   強大的[路由](https://docs.gofiber.io/guide/routing)
   147  -   [靜態檔案](https://docs.gofiber.io/api/app#static)服務
   148  -   [超快速](https://docs.gofiber.io/extra/benchmarks)
   149  -   [佔用很少記憶體](https://docs.gofiber.io/extra/benchmarks)
   150  -   支援 Express 的[API](https://docs.gofiber.io/api/ctx)
   151  -   支援中介器和[下一步](https://docs.gofiber.io/api/ctx#next)
   152  -   [立即上手](https://dev.to/koddr/welcome-to-fiber-an-express-js-styled-fastest-web-framework-written-with-on-golang-497)
   153  -   [樣板引擎](https://github.com/gofiber/template)
   154  -   [支援 WebSocket](https://github.com/gofiber/websocket)
   155  -   [Server-Sent Events](https://github.com/gofiber/recipes/tree/master/sse)
   156  -   支援[速率限制](https://docs.gofiber.io/api/middleware/limiter)
   157  -   有 [18 門語言](https://docs.gofiber.io/)的翻譯
   158  -   還有很多功能,[開始探索 Fiber](https://docs.gofiber.io/)
   159  
   160  ## 💡 設計哲學
   161  
   162  從 [Node.js](https://nodejs.org/en/about/) 轉到 [Go](https://go.dev/doc/) 的新進 Go 開發者,得先面對 Go 的各種知識點,才能開始建構自己的 Web 應用程式或微服務。Fiber 作為一款 **Web 框架**,設計之初便以 **極簡主義** 為理念,並遵循 **UNIX 之道**,讓新進 Go 開發者能夠快速隨著友善且值得信賴的社群,進入 Go 的世界。
   163  
   164  Fiber **啟發自** Express——網際網路上最知名的 Web 框架,我們將 Express 的 **易用性** 和 Go 的 **原始效能** 結合在一起。如果您曾經在 Node.js(使用 Express 或類似框架)實作過 Web 應用程式,那麼許多方法和開發準則,將讓您感到 **無比熟悉**。
   165  
   166  我們 **傾聽** 使用者在 [Issues](https://github.com/gofiber/fiber/issues)、Discord [群組](https://gofiber.io/discord) 和 **網路上任何角落** 的意見和建議,製作出 **快速**、**靈活** 且 **易於上手** 的 Go Web 框架,來應對**任何**工作、**繳件期限**以及開發者的**能力區間**——如同 Express 在 JavaScript 世界所扮演的角色一樣!
   167  
   168  ## ⚠️ 限制
   169  
   170  -   由於 Fiber 有用到 Unsafe,本函式庫有時可能無法相容最新版的 Go 語言。Fiber 2.40.0 已在 Go 1.17 至 1.20 的版本測試過。
   171  -   Fiber 不相容 net/http 的介面,意味著您無法使用像是 gqlgen、go-swagger 或其他任何屬於 net/http 生態系統的專案。
   172  
   173  ## 👀 範例
   174  
   175  下方列出一些常見範例。如果您想查看更多程式碼範例,請參閱我們的 [Recipes 儲存庫](https://github.com/gofiber/recipes),或前往我們提供的 [API 文件](https://docs.gofiber.io)。
   176  
   177  #### 📖 [**基礎路由**](https://docs.gofiber.io/#basic-routing)
   178  
   179  ```go
   180  func main() {
   181      app := fiber.New()
   182  
   183      // GET /api/register
   184      app.Get("/api/*", func(c *fiber.Ctx) error {
   185          msg := fmt.Sprintf("✋ %s", c.Params("*"))
   186          return c.SendString(msg) // => ✋ register
   187      })
   188  
   189      // GET /flights/LAX-SFO
   190      app.Get("/flights/:from-:to", func(c *fiber.Ctx) error {
   191          msg := fmt.Sprintf("💸 從:%s,到:%s", c.Params("from"), c.Params("to"))
   192          return c.SendString(msg) // => 💸 從:LAX,到:SFO
   193      })
   194  
   195      // GET /dictionary.txt
   196      app.Get("/:file.:ext", func(c *fiber.Ctx) error {
   197          msg := fmt.Sprintf("📃 %s.%s", c.Params("file"), c.Params("ext"))
   198          return c.SendString(msg) // => 📃 dictionary.txt
   199      })
   200  
   201      // GET /john/75
   202      app.Get("/:name/:age/:gender?", func(c *fiber.Ctx) error {
   203          msg := fmt.Sprintf("👴 %s 已經 %s 歲了", c.Params("name"), c.Params("age"))
   204          return c.SendString(msg) // => 👴 john 已經 75 歲了
   205      })
   206  
   207      // GET /john
   208      app.Get("/:name", func(c *fiber.Ctx) error {
   209          msg := fmt.Sprintf("哈囉,%s 👋!", c.Params("name"))
   210          return c.SendString(msg) // => 哈囉,john 👋!
   211      })
   212  
   213      log.Fatal(app.Listen(":3000"))
   214  }
   215  
   216  ```
   217  
   218  #### 📖 [**路由命名**](https://docs.gofiber.io/api/app#name)
   219  
   220  ```go
   221  func main() {
   222      app := fiber.New()
   223  
   224      // GET /api/register
   225      app.Get("/api/*", func(c *fiber.Ctx) error {
   226          msg := fmt.Sprintf("✋ %s", c.Params("*"))
   227          return c.SendString(msg) // => ✋ register
   228      }).Name("api")
   229  
   230      data, _ := json.MarshalIndent(app.GetRoute("api"), "", "  ")
   231      fmt.Print(string(data))
   232      // 會輸出:
   233      // {
   234      //    "method": "GET",
   235      //    "name": "api",
   236      //    "path": "/api/*",
   237      //    "params": [
   238      //      "*1"
   239      //    ]
   240      // }
   241  
   242  
   243      log.Fatal(app.Listen(":3000"))
   244  }
   245  
   246  ```
   247  
   248  #### 📖 [**寄存靜態檔案**](https://docs.gofiber.io/api/app#static)
   249  
   250  ```go
   251  func main() {
   252      app := fiber.New()
   253  
   254      app.Static("/", "./public")
   255      // => http://localhost:3000/js/script.js
   256      // => http://localhost:3000/css/style.css
   257  
   258      app.Static("/prefix", "./public")
   259      // => http://localhost:3000/prefix/js/script.js
   260      // => http://localhost:3000/prefix/css/style.css
   261  
   262      app.Static("*", "./public/index.html")
   263      // => http://localhost:3000/any/path/shows/index/html
   264  
   265      log.Fatal(app.Listen(":3000"))
   266  }
   267  
   268  ```
   269  
   270  #### 📖 [**中介模組和接續函式 (Next)**](https://docs.gofiber.io/api/ctx#next)
   271  
   272  ```go
   273  func main() {
   274      app := fiber.New()
   275  
   276      // 符合任何路由
   277      app.Use(func(c *fiber.Ctx) error {
   278          fmt.Println("🥇 第一個處理常式")
   279          return c.Next()
   280      })
   281  
   282      // 符合所有 /api 開頭的路由
   283      app.Use("/api", func(c *fiber.Ctx) error {
   284          fmt.Println("🥈 第二個處理常式")
   285          return c.Next()
   286      })
   287  
   288      // GET /api/list
   289      app.Get("/api/list", func(c *fiber.Ctx) error {
   290          fmt.Println("🥉 最後一個處理常式")
   291          return c.SendString("Hello, World 👋!")
   292      })
   293  
   294      log.Fatal(app.Listen(":3000"))
   295  }
   296  
   297  ```
   298  
   299  <details>
   300    <summary>📚 展示更多程式碼範例</summary>
   301  
   302  ### 檢視引擎
   303  
   304  📖 [組態設定](https://docs.gofiber.io/api/fiber#config)
   305  📖 [引擎](https://github.com/gofiber/template)
   306  📖 [轉譯 (render)](https://docs.gofiber.io/api/ctx#render)
   307  
   308  若未指定檢視引擎,Fiber 預設採用 [html/template](https://pkg.go.dev/html/template/)。
   309  
   310  如果您想執行部分檢視 (partials),或者是使用如 [amber](https://github.com/eknkc/amber)、[handlebars](https://github.com/aymerick/raymond)、[mustache](https://github.com/cbroglie/mustache) 或 [pug](https://github.com/Joker/jade) 等等不同的引擎……
   311  
   312  請參考我們的 [Template](https://github.com/gofiber/template) 套件——它支援多種檢視引擎。
   313  
   314  ```go
   315  package main
   316  
   317  import (
   318      "github.com/boomhut/fiber/v2"
   319      "github.com/gofiber/template/pug"
   320  )
   321  
   322  func main() {
   323      // 您可以在 app 初始化前設定檢視 (Views) 引擎:
   324      app := fiber.New(fiber.Config{
   325          Views: pug.New("./views", ".pug"),
   326      })
   327  
   328      // 現在,您可以用下面這種方式呼叫 `./views/home.pug` 樣板:
   329      app.Get("/", func(c *fiber.Ctx) error {
   330          return c.Render("home", fiber.Map{
   331              "title": "Homepage",
   332              "year":  1999,
   333          })
   334      })
   335  
   336      log.Fatal(app.Listen(":3000"))
   337  }
   338  ```
   339  
   340  ### 組合路由鏈
   341  
   342  📖 [分組](https://docs.gofiber.io/api/app#group)
   343  
   344  ```go
   345  func middleware(c *fiber.Ctx) error {
   346      fmt.Println("不要理我!")
   347      return c.Next()
   348  }
   349  
   350  func handler(c *fiber.Ctx) error {
   351      return c.SendString(c.Path())
   352  }
   353  
   354  func main() {
   355      app := fiber.New()
   356  
   357      // 根 API 路由
   358      api := app.Group("/api", middleware) // /api
   359  
   360      // API v1 路由
   361      v1 := api.Group("/v1", middleware) // /api/v1
   362      v1.Get("/list", handler)           // /api/v1/list
   363      v1.Get("/user", handler)           // /api/v1/user
   364  
   365      // API v2 路由
   366      v2 := api.Group("/v2", middleware) // /api/v2
   367      v2.Get("/list", handler)           // /api/v2/list
   368      v2.Get("/user", handler)           // /api/v2/user
   369  
   370      // ...
   371  }
   372  
   373  ```
   374  
   375  ### 中介模組記錄器
   376  
   377  📖 [記錄器](https://docs.gofiber.io/api/middleware/logger)
   378  
   379  ```go
   380  package main
   381  
   382  import (
   383      "log"
   384  
   385      "github.com/boomhut/fiber/v2"
   386      "github.com/gofiber/fiber/v2/middleware/logger"
   387  )
   388  
   389  func main() {
   390      app := fiber.New()
   391  
   392      app.Use(logger.New())
   393  
   394      // ...
   395  
   396      log.Fatal(app.Listen(":3000"))
   397  }
   398  ```
   399  
   400  ### 跨原始來源資源共用 (CORS)
   401  
   402  📖 [CORS](https://docs.gofiber.io/api/middleware/cors)
   403  
   404  ```go
   405  import (
   406      "log"
   407  
   408      "github.com/boomhut/fiber/v2"
   409      "github.com/gofiber/fiber/v2/middleware/cors"
   410  )
   411  
   412  func main() {
   413      app := fiber.New()
   414  
   415      app.Use(cors.New())
   416  
   417      // ...
   418  
   419      log.Fatal(app.Listen(":3000"))
   420  }
   421  ```
   422  
   423  在 `Origin` 標頭傳入任何網域來檢查 CORS 的效果:
   424  
   425  ```bash
   426  curl -H "Origin: http://example.com" --verbose http://localhost:3000
   427  ```
   428  
   429  ### 自訂 404 回應
   430  
   431  📖 [HTTP 方法](https://docs.gofiber.io/api/ctx#status)
   432  
   433  ```go
   434  func main() {
   435      app := fiber.New()
   436  
   437      app.Static("/", "./public")
   438  
   439      app.Get("/demo", func(c *fiber.Ctx) error {
   440          return c.SendString("This is a demo!")
   441      })
   442  
   443      app.Post("/register", func(c *fiber.Ctx) error {
   444          return c.SendString("Welcome!")
   445      })
   446  
   447      // 最後一個中介模組,符合所有條件
   448      app.Use(func(c *fiber.Ctx) error {
   449          return c.SendStatus(404)
   450          // => 404 "Not Found"
   451      })
   452  
   453      log.Fatal(app.Listen(":3000"))
   454  }
   455  ```
   456  
   457  ### JSON 回應
   458  
   459  📖 [JSON](https://docs.gofiber.io/api/ctx#json)
   460  
   461  ```go
   462  type User struct {
   463      Name string `json:"name"`
   464      Age  int    `json:"age"`
   465  }
   466  
   467  func main() {
   468      app := fiber.New()
   469  
   470      app.Get("/user", func(c *fiber.Ctx) error {
   471          return c.JSON(&User{"John", 20})
   472          // => {"name":"John", "age":20}
   473      })
   474  
   475      app.Get("/json", func(c *fiber.Ctx) error {
   476          return c.JSON(fiber.Map{
   477              "success": true,
   478              "message": "Hi John!",
   479          })
   480          // => {"success":true, "message":"Hi John!"}
   481      })
   482  
   483      log.Fatal(app.Listen(":3000"))
   484  }
   485  ```
   486  
   487  ### WebSocket 升級 (Upgrade)
   488  
   489  📖 [Websocket](https://github.com/gofiber/websocket)
   490  
   491  ```go
   492  import (
   493      "github.com/boomhut/fiber/v2"
   494      "github.com/gofiber/fiber/v2/middleware/websocket"
   495  )
   496  
   497  func main() {
   498    app := fiber.New()
   499  
   500    app.Get("/ws", websocket.New(func(c *websocket.Conn) {
   501      for {
   502        mt, msg, err := c.ReadMessage()
   503        if err != nil {
   504          log.Println("read:", err)
   505          break
   506        }
   507        log.Printf("recv: %s", msg)
   508        err = c.WriteMessage(mt, msg)
   509        if err != nil {
   510          log.Println("write:", err)
   511          break
   512        }
   513      }
   514    }))
   515  
   516    log.Fatal(app.Listen(":3000"))
   517    // ws://localhost:3000/ws
   518  }
   519  ```
   520  
   521  ### Server-Sent Events
   522  
   523  📖 [更多資訊](https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events)
   524  
   525  ```go
   526  import (
   527      "github.com/boomhut/fiber/v2"
   528      "github.com/valyala/fasthttp"
   529  )
   530  
   531  func main() {
   532    app := fiber.New()
   533  
   534    app.Get("/sse", func(c *fiber.Ctx) error {
   535      c.Set("Content-Type", "text/event-stream")
   536      c.Set("Cache-Control", "no-cache")
   537      c.Set("Connection", "keep-alive")
   538      c.Set("Transfer-Encoding", "chunked")
   539  
   540      c.Context().SetBodyStreamWriter(fasthttp.StreamWriter(func(w *bufio.Writer) {
   541        fmt.Println("WRITER")
   542        var i int
   543  
   544        for {
   545          i++
   546          msg := fmt.Sprintf("%d - 目前時間為 %v", i, time.Now())
   547          fmt.Fprintf(w, "data: 訊息: %s\n\n", msg)
   548          fmt.Println(msg)
   549  
   550          w.Flush()
   551          time.Sleep(5 * time.Second)
   552        }
   553      }))
   554  
   555      return nil
   556    })
   557  
   558    log.Fatal(app.Listen(":3000"))
   559  }
   560  ```
   561  
   562  ### Recover 中介模組
   563  
   564  📖 [Recover](https://docs.gofiber.io/api/middleware/recover)
   565  
   566  ```go
   567  import (
   568      "github.com/boomhut/fiber/v2"
   569      "github.com/gofiber/fiber/v2/middleware/recover"
   570  )
   571  
   572  func main() {
   573      app := fiber.New()
   574  
   575      app.Use(recover.New())
   576  
   577      app.Get("/", func(c *fiber.Ctx) error {
   578          panic("正常來說,這會導致 app 當機")
   579      })
   580  
   581      log.Fatal(app.Listen(":3000"))
   582  }
   583  ```
   584  
   585  </details>
   586  
   587  ### 使用信任的代理伺服器
   588  
   589  📖 [組態設定](https://docs.gofiber.io/api/fiber#config)
   590  
   591  ```go
   592  import (
   593      "github.com/boomhut/fiber/v2"
   594      "github.com/gofiber/fiber/v2/middleware/recover"
   595  )
   596  
   597  func main() {
   598      app := fiber.New(fiber.Config{
   599          EnableTrustedProxyCheck: true,
   600          TrustedProxies: []string{"0.0.0.0", "1.1.1.1/30"}, // IP 地址或 IP 地址區間
   601          ProxyHeader: fiber.HeaderXForwardedFor,
   602      })
   603  
   604      // ...
   605  
   606      log.Fatal(app.Listen(":3000"))
   607  }
   608  ```
   609  
   610  </details>
   611  
   612  ## 🧬 內建中介模組
   613  
   614  這裡列出了 Fiber 框架內建的中介模組。
   615  
   616  | 中介模組                                                                               | 描述                                                                                                                                                                       |
   617  | :------------------------------------------------------------------------------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
   618  | [basicauth](https://github.com/gofiber/fiber/tree/master/middleware/basicauth)         | 提供 HTTP Basic 認證的基本認證中介模組。如果憑證有效,則會呼叫接續函式 (next);如果沒有憑證或失效,則回傳 401 Unauthorized。                                               |
   619  | [cache](https://github.com/gofiber/fiber/tree/master/middleware/cache)                 | 攔截並快取回應。                                                                                                                                                           |
   620  | [compress](https://github.com/gofiber/fiber/tree/master/middleware/compress)           | 適用於 Fiber 的壓縮中介模組。預設支援 `deflate`、`gzip` 和 `brotli`。                                                                                                      |
   621  | [cors](https://github.com/gofiber/fiber/tree/master/middleware/cors)                   | 啟用跨來源資源共用 (CORS),可調整多種選項。                                                                                                                                |
   622  | [csrf](https://github.com/gofiber/fiber/tree/master/middleware/csrf)                   | 保護資源防止 CSRF 利用。                                                                                                                                                   |
   623  | [encryptcookie](https://github.com/gofiber/fiber/tree/master/middleware/encryptcookie) | 加密中介模組,會將 Cookie 的值進行加密。                                                                                                                                   |
   624  | [envvar](https://github.com/gofiber/fiber/tree/master/middleware/envvar)               | 公開環境變數,並提供可調整設定。                                                                                                                                           |
   625  | [etag](https://github.com/gofiber/fiber/tree/master/middleware/etag)                   | ETag 中介模組,讓快取更高效,同時因為 Web 伺服器不需要在內容未更動時重新傳送完整請求,因此可以減少流量使用。                                                               |
   626  | [expvar](https://github.com/gofiber/fiber/tree/master/middleware/expvar)               | Expvar 中介模組,透過其 HTTP 伺服器執行階段,提供 JSON 格式的公用變數。                                                                                                    |
   627  | [favicon](https://github.com/gofiber/fiber/tree/master/middleware/favicon)             | 不輸出 Favicons 請求記錄;若有提供檔案路徑,則從記憶體提供圖示。                                                                                                           |
   628  | [filesystem](https://github.com/gofiber/fiber/tree/master/middleware/filesystem)       | 適用於 Fiber 的檔案系統中介模組。特別銘謝 Alireza Salary!                                                                                                                 |
   629  | [limiter](https://github.com/gofiber/fiber/tree/master/middleware/limiter)             | 適用於 Fiber 的速率限制中介模組。用來限制傳入公開 API 或者(以及)端點(如密碼重設)的重複請求。                                                                           |
   630  | [logger](https://github.com/gofiber/fiber/tree/master/middleware/logger)               | HTTP 請求/回應記錄工具。                                                                                                                                                   |
   631  | [monitor](https://github.com/gofiber/fiber/tree/master/middleware/monitor)             | 監控中介模組,用來回報伺服器指標。啟發自 express-status-monitor。                                                                                                          |
   632  | [pprof](https://github.com/gofiber/fiber/tree/master/middleware/pprof)                 | 特別感謝 Matthew Lee \(@mthli\)                                                                                                                                            |
   633  | [proxy](https://github.com/gofiber/fiber/tree/master/middleware/proxy)                 | 讓您可以將請求代理 (proxy) 至多台伺服器。                                                                                                                                  |
   634  | [recover](https://github.com/gofiber/fiber/tree/master/middleware/recover)             | Recover 中介模組:可以從呼叫堆疊鏈中任何部分的當機 (panic) 中復原,並將控制權交由中央的 [錯誤處理常式 (ErrorHandler)](https://docs.gofiber.io/guide/error-handling) 處理。 |
   635  | [requestid](https://github.com/gofiber/fiber/tree/master/middleware/requestid)         | 為每個請求加上 requestid。                                                                                                                                                 |
   636  | [session](https://github.com/gofiber/fiber/tree/master/middleware/session)             | 連線階段中介模組。注意:這個中介模組有用到我們的 Storage 套件。                                                                                                            |
   637  | [skip](https://github.com/gofiber/fiber/tree/master/middleware/skip)                   | 略過中介模組,會在條件成立時略過封裝過的處理常式。                                                                                                                         |
   638  | [timeout](https://github.com/gofiber/fiber/tree/master/middleware/timeout)             | 為請求加上最長時限,並在逾時後轉送至錯誤處理常式 (ErrorHandler)。                                                                                                          |
   639  | [keyauth](https://github.com/gofiber/keyauth)     | Key auth 中介模組提供以金鑰為基礎的認證模式。                                                          |
   640  | [redirect](https://github.com/gofiber/redirect)   | 用來重新導向的中介模組。                                                                               |
   641  | [rewrite](https://github.com/gofiber/rewrite)     | 重寫 (Rewrite) 中介模組:根據提供規則重寫 URL 路徑,適合用來向後相容,或者是製作更乾淨且更好懂的連結。 |
   642  | [adaptor](https://github.com/gofiber/adaptor)     | 將 net/http 處理常式轉換至 Fiber 處理常式,或者是反著做。特別感謝 @arsmn!                             |
   643  | [helmet](https://github.com/gofiber/helmet)       | 透過設定多種 HTTP 標頭,協助保護您應用程式的安全。                                                     |
   644  
   645  ## 🧬 外掛中介模組
   646  
   647  這裡列出由 [Fiber 團隊](https://github.com/orgs/gofiber/people) 維護、存放在外部的中介模組。
   648  
   649  | 中介模組                                          | 描述                                                                                                   |
   650  | :------------------------------------------------ | :----------------------------------------------------------------------------------------------------- |
   651  | [jwt](https://github.com/gofiber/jwt)             | JWT 回傳 JSON Web Token \(JWT\) 認證中介模組。                                                         |
   652  | [storage](https://github.com/gofiber/storage)     | 已經做好,實作 Storage 介面的儲存區驅動模組,設計用來與各種 Fiber 中介模組搭配使用。                   |
   653  | [template](https://github.com/gofiber/template)   | 本套件包含 8 種樣板引擎,可以和 Fiber `v1.10.x` 一起使用。需要 Go 1.13 或更新版本。                    |
   654  | [websocket](https://github.com/gofiber/websocket) | 適用於 Fiber,建基於 Fasthttp 的 WebSocket。支援本機空間 (Locals)!                                    |
   655  
   656  ## 🕶️ Awesome List
   657  
   658  更多文章、中介模組、範例或工具,請參考我們的 [Awesome List](https://github.com/gofiber/awesome-fiber)。
   659  
   660  ## 👍 貢獻
   661  
   662  如果您想和我們 **道謝**,或者是支持 `Fiber` 繼續積極開發下去(也可以兩個都做):
   663  
   664  1. 送給專案一顆 [GitHub 星星](https://github.com/gofiber/fiber/stargazers)。
   665  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)發出關於本專案的推文。
   666  3. 在 [Medium](https://medium.com/)、[Dev.to](https://dev.to/) 或者是個人部落格上寫下評論或教學。
   667  4. 捐專案 [一杯咖啡的費用](https://buymeacoff.ee/fenny) 以示支持。
   668  
   669  ## ☕ 支持者
   670  
   671  Fiber 是個仰賴捐款的開放原始碼專案——用來支付如域名、Gitbook、Netlify 和無服務器運算服務的費用。如果您想支持 Fiber,可以在 ☕ [**這裡捐杯咖啡**](https://buymeacoff.ee/fenny)。
   672  
   673  |                                                            | 使用者                                           | 捐款    |
   674  | :--------------------------------------------------------- | :----------------------------------------------- | :------ |
   675  | ![](https://avatars.githubusercontent.com/u/204341?s=25)   | [@destari](https://github.com/destari)           | ☕ x 10 |
   676  | ![](https://avatars.githubusercontent.com/u/63164982?s=25) | [@dembygenesis](https://github.com/dembygenesis) | ☕ x 5  |
   677  | ![](https://avatars.githubusercontent.com/u/56607882?s=25) | [@thomasvvugt](https://github.com/thomasvvugt)   | ☕ x 5  |
   678  | ![](https://avatars.githubusercontent.com/u/27820675?s=25) | [@hendratommy](https://github.com/hendratommy)   | ☕ x 5  |
   679  | ![](https://avatars.githubusercontent.com/u/1094221?s=25)  | [@ekaputra07](https://github.com/ekaputra07)     | ☕ x 5  |
   680  | ![](https://avatars.githubusercontent.com/u/194590?s=25)   | [@jorgefuertes](https://github.com/jorgefuertes) | ☕ x 5  |
   681  | ![](https://avatars.githubusercontent.com/u/186637?s=25)   | [@candidosales](https://github.com/candidosales) | ☕ x 5  |
   682  | ![](https://avatars.githubusercontent.com/u/29659953?s=25) | [@l0nax](https://github.com/l0nax)               | ☕ x 3  |
   683  | ![](https://avatars.githubusercontent.com/u/635852?s=25)   | [@bihe](https://github.com/bihe)                 | ☕ x 3  |
   684  | ![](https://avatars.githubusercontent.com/u/307334?s=25)   | [@justdave](https://github.com/justdave)         | ☕ x 3  |
   685  | ![](https://avatars.githubusercontent.com/u/11155743?s=25) | [@koddr](https://github.com/koddr)               | ☕ x 1  |
   686  | ![](https://avatars.githubusercontent.com/u/29042462?s=25) | [@lapolinar](https://github.com/lapolinar)       | ☕ x 1  |
   687  | ![](https://avatars.githubusercontent.com/u/2978730?s=25)  | [@diegowifi](https://github.com/diegowifi)       | ☕ x 1  |
   688  | ![](https://avatars.githubusercontent.com/u/44171355?s=25) | [@ssimk0](https://github.com/ssimk0)             | ☕ x 1  |
   689  | ![](https://avatars.githubusercontent.com/u/5638101?s=25)  | [@raymayemir](https://github.com/raymayemir)     | ☕ x 1  |
   690  | ![](https://avatars.githubusercontent.com/u/619996?s=25)   | [@melkorm](https://github.com/melkorm)           | ☕ x 1  |
   691  | ![](https://avatars.githubusercontent.com/u/31022056?s=25) | [@marvinjwendt](https://github.com/marvinjwendt) | ☕ x 1  |
   692  | ![](https://avatars.githubusercontent.com/u/31921460?s=25) | [@toishy](https://github.com/toishy)             | ☕ x 1  |
   693  
   694  ## ‎‍💻 程式碼貢獻者
   695  
   696  <img src="https://opencollective.com/fiber/contributors.svg?width=890&button=false" alt="Code Contributors" style="max-width:100%;">
   697  
   698  ## ⭐️ 收藏數
   699  
   700  <img src="https://starchart.cc/gofiber/fiber.svg" alt="Stargazers over time" style="max-width: 100%">
   701  
   702  ## ⚠️ 授權條款
   703  
   704  著作權所有 (c) 2019-現在 [Fenny](https://github.com/fenny) 和[貢獻者](https://github.com/gofiber/fiber/graphs/contributors)。`Fiber` 是款依照 [MIT License](https://github.com/gofiber/fiber/blob/master/LICENSE) 授權,免費且開放原始碼的軟體。官方圖示 (logo) 由 [Vic Shóstak](https://github.com/koddr) 製作,並依據 [創用 CC](https://creativecommons.org/licenses/by-sa/4.0/) 授權條款散佈 (CC BY-SA 4.0 International)。
   705  
   706  **第三方函式庫的授權條款**
   707  
   708  -   [colorable](https://github.com/mattn/go-colorable/blob/master/LICENSE)
   709  -   [isatty](https://github.com/mattn/go-isatty/blob/master/LICENSE)
   710  -   [runewidth](https://github.com/mattn/go-runewidth/blob/master/LICENSE)
   711  -   [fasthttp](https://github.com/valyala/fasthttp/blob/master/LICENSE)
   712  -   [bytebufferpool](https://github.com/valyala/bytebufferpool/blob/master/LICENSE)
   713  -   [dictpool](https://github.com/savsgio/dictpool/blob/master/LICENSE)
   714  -   [fwd](https://github.com/philhofer/fwd/blob/master/LICENSE.md)
   715  -   [go-ole](https://github.com/go-ole/go-ole/blob/master/LICENSE)
   716  -   [gopsutil](https://github.com/shirou/gopsutil/blob/master/LICENSE)
   717  -   [msgp](https://github.com/tinylib/msgp/blob/master/LICENSE)
   718  -   [schema](https://github.com/gorilla/schema/blob/master/LICENSE)
   719  -   [uuid](https://github.com/google/uuid/blob/master/LICENSE)
   720  -   [wmi](https://github.com/StackExchange/wmi/blob/master/LICENSE)