Fiber is an Express inspired web framework built on top of Fasthttp, the fastest HTTP engine for Go. Designed to ease things up for fast development with zero memory allocation and performance in mind.
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")
}
These tests are performed by TechEmpower and Go Web. If you want to see all results, please visit our Wiki.
Make sure you have Go installed (download). Version 1.14
or higher is required.
Initialize your project by creating a folder and then running go mod init github.com/your/repo
(learn more) inside the folder. Then install Fiber with the go get
command:
go get -u github.com/gofiber/fiber/v2
New gophers that make the switch from Node.js to Go are dealing with a learning curve before they can start building their web applications or microservices. Fiber, as a web framework, was created with the idea of minimalism and follows the UNIX way, so that new gophers can quickly enter the world of Go with a warm and trusted welcome.
Fiber is inspired by Express, the most popular web framework on the Internet. We combined the ease of Express and raw performance of Go. If you have ever implemented a web application in Node.js (using Express or similar), then many methods and principles will seem very common to you.
We listen to our users in issues, Discord channel and all over the Internet to create a fast, flexible and friendly Go web framework for any task, deadline and developer skill! Just like Express does in the JavaScript world.
Listed below are some of the common examples. If you want to see more code examples , please visit our Recipes repository or visit our hosted API documentation.
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"))
}
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"))
}
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"))
}
Fiber defaults to the html/template when no view engine is set.
If you want to execute partials or use a different engine like amber, handlebars, mustache or pug etc..
Checkout our Template package that support multiple view engines.
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"))
}
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
// ...
}
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"))
}
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"))
}
Check CORS by passing any domain in Origin
header:
curl -H "Origin: http://example.com" --verbose http://localhost:3000
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"))
}
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"))
}
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
}
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"))
}
Here is a list of middleware that are included within the Fiber framework.
Middleware | Description |
---|---|
basicauth | Basic auth middleware provides an HTTP basic authentication. It calls the next handler for valid credentials and 401 Unauthorized for missing or invalid credentials. |
compress | Compression middleware for Fiber, it supports deflate , gzip and brotli by default. |
cache | Intercept and cache responses |
cors | Enable cross-origin resource sharing (CORS) with various options. |
csrf | Protect from CSRF exploits. |
filesystem | FileSystem middleware for Fiber, special thanks and credits to Alireza Salary |
favicon | Ignore favicon from logs or serve from memory if a file path is provided. |
limiter | Rate-limiting middleware for Fiber. Use to limit repeated requests to public APIs and/or endpoints such as password reset. |
logger | HTTP request/response logger. |
pprof | Special thanks to Matthew Lee (@mthli) |
proxy | Allows you to proxy requests to a multiple servers |
requestid | Adds a requestid to every request. |
recover | Recover middleware recovers from panics anywhere in the stack chain and handles the control to the centralized ErrorHandler. |
timeout | Adds a max time for a request and forwards to ErrorHandler if it is exceeded. |
List of externally hosted middleware modules and maintained by the Fiber team.
Middleware | Description |
---|---|
adaptor | Converter for net/http handlers to/from Fiber request handlers, special thanks to @arsmn! |
helmet | Helps secure your apps by setting various HTTP headers. |
jwt | JWT returns a JSON Web Token (JWT) auth middleware. |
keyauth | Key auth middleware provides a key based authentication. |
rewrite | Rewrite middleware rewrites the URL path based on provided rules. It can be helpful for backward compatibility or just creating cleaner and more descriptive links. |
session | This session middleware is build on top of fasthttp/session by @savsgio MIT. Special thanks to @thomasvvugt for helping with this middleware. |
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 | Based on Fasthttp WebSocket for Fiber with Locals support! |
This is a list of middlewares that are created by the Fiber community, please create a PR if you want to see yours!
If you want to say thank you and/or support the active development of Fiber
:
Fiber is an open source project that runs on donations to pay the bills e.g. our domain name, gitbook, netlify and serverless hosting. If you want to support Fiber, you can
User | Donation | |
---|---|---|
@destari |
|
|
@dembygenesis |
|
|
@thomasvvugt |
|
|
@hendratommy |
|
|
@ekaputra07 |
|
|
@jorgefuertes |
|
|
@candidosales |
|
|
@l0nax |
|
|
@ankush |
|
|
@bihe |
|
|
@justdave |
|
|
@koddr |
|
|
@lapolinar |
|
|
@diegowifi |
|
|
@ssimk0 |
|
|
@raymayemir |
|
|
@melkorm |
|
|
@marvinjwendt |
|
|
@toishy |
|
Copyright (c) 2019-present Fenny and Contributors. Fiber
is free and open-source software licensed under the MIT License. Official logo was created by Vic Shóstak and distributed under Creative Commons license (CC BY-SA 4.0 International).
Third-party library licenses
title: 对fiber的了解 order: 1 看了一篇官网推荐的Github文章,一篇淘系前端文章,快速看了掘金两篇大佬文章,写下这篇总结 Fiber 是 React 16 中新的协调引擎。它的主要目的是使 Virtual DOM 可以进行增量式渲染。了解更多. Fiber reconciler “fiber” reconciler(调节器,用来diff的) 是一个新尝试,致力于解决 sta
什么是fiber Fiber 是一个执行单元。 fiber是react16 对核心算法的依次重写,fiber会使原本同步的渲染过程变成异步的。 同步渲染的递归调用栈是非常深的,且是漫长而不可打断的更新过程。因此将会带来很大的风险:同步渲染一旦开始将会牢牢的抓住主线程不放,直到递归完成。这段时间浏览器无法处理任何渲染之外的事情,会进入一种无法处理用户交互的状态 Fiber 是一种数据结构,支撑 Fi
问题内容: 这个程序 这样死 我觉得这很令人困惑。为什么它不起作用,我是否有错?如果是这样,我该怎么做?除非我掩盖了某些内容,否则根据em-synchrony自述文件,这是洁食。 问题答案: 我认为,如果您找到正确的em-hiredis版本并尝试猴子补丁,那么您的代码就可以工作,这是依赖项松散的问题之一。 这是一个完全正常的代码,但是基于em-synchrony的master分支: 宝石文件: t
本文向大家介绍React Fiber它的目的是解决什么问题?相关面试题,主要包含被问及React Fiber它的目的是解决什么问题?时的应答技巧和注意事项,需要的朋友参考一下 React的Reconciler 层负责组建的生命周期运算,diff运算等, React15中被命名为Stack Reconciler,运行过程不能中断,当页面元素较多,执行时间过长,超过16s的时候,就会出现掉帧的现象。
本文向大家介绍说说你对Fiber架构的理解相关面试题,主要包含被问及说说你对Fiber架构的理解时的应答技巧和注意事项,需要的朋友参考一下 React 15 的 StackReconciler 方案由于递归不可中断问题,如果 Diff 时间过长(JS计算时间),会造成页面 UI 的无响应的表现,vdom 无法应用到 dom 中。 为了解决这个问题,React 16 实现了新的基于 requestI
问题内容: 我在使用Fibers / Meteor.bindEnvironment()时遇到困难。如果集合开始为空,我试图进行代码更新并插入到集合中。所有这些都应该在启动时在服务器端运行。 我第一次编写此文件时,遇到了一些错误,需要将回调包装在Fiber()块中,然后在IRC上讨论时,有人建议尝试使用Meteor.bindEnvironment(),因为那应该将其放入Fiber中。那是行不通的(我
在构建基于光纤的塔兰托应用程序时,我遇到了一个意外的行为。 我的代码的简单复制器如下所示: 并打印到日志。此外,如果我使用以下: 它打印到log,如果我使用 它打印到log。 我预计在运行后,如果控件返回到外部光纤并调用,那么下次控件返回到取消的时,我们将进入循环迭代的末尾,在下一次迭代中,代码将成功返回1。但是,的工作结束时抛出错误,而不是返回。那么,生产纤维的真实生命周期是如何运作的呢?
通过上一节的学习,我们了解了Fiber是什么,知道Fiber节点可以保存对应的DOM节点。 相应的,Fiber节点构成的Fiber树就对应DOM树。 那么如何更新DOM呢?这需要用到被称为“双缓存”的技术。 什么是“双缓存” 当我们用canvas绘制动画,每一帧绘制前都会调用ctx.clearRect清除上一帧的画面。 如果当前帧画面计算量比较大,导致清除上一帧画面到绘制当前帧画面之间有较长间隙,
在中,我们提到的虚拟DOM在React中有个正式的称呼——Fiber。在之后的学习中,我们会逐渐用Fiber来取代React16虚拟DOM这一称呼。 接下来让我们了解下Fiber因何而来?他的作用是什么? Fiber的起源 最早的Fiber官方解释来源于2016年React团队成员Acdlite的一篇介绍。 从上一章的学习我们知道: 在React15及以前,Reconciler采用递归的方式创建虚
React核心团队成员Sebastian Markbåge(React Hooks的发明者)曾说:我们在React中做的就是践行代数效应(Algebraic Effects)。 那么,代数效应是什么呢?他和React有什么关系呢。 什么是代数效应 代数效应是函数式编程中的一个概念,用于将副作用从函数调用中分离。 接下来我们用虚构的语法来解释。 假设我们有一个函数getTotalPicNum,传入2