mirror of
https://github.com/gofiber/fiber.git
synced 2025-02-22 22:43:54 +00:00
Update README.md
This commit is contained in:
parent
ec1ba416bf
commit
578f4a793c
95
README.md
95
README.md
@ -1,113 +1,146 @@
|
||||
<p align="center">
|
||||
<img height="150" src="https://gofiber.github.io/fiber/static/logo.jpg">
|
||||
</p>
|
||||
<!--
|
||||
data:image/s3,"s3://crabby-images/44ac7/44ac7b52f4c2e58bf2deb7ca755ea0857d2c77c2" alt=""
|
||||
data:image/s3,"s3://crabby-images/bc780/bc78038b2d2b68698ee8a6581078d4107ced8d0b" alt=""
|
||||
-->
|
||||
# Fiber Web Framework <img src="images/flags/en.svg" alt="en"/> <a href="README_RU.md"><img src="images/flags/ru.svg" alt="ru"/></a>
|
||||
|
||||
# Fiber [data:image/s3,"s3://crabby-images/278a5/278a5eb5c59913bc0bfd456a47786d36a4ec754c" alt=""](https://github.com/gofiber/fiber/releases) data:image/s3,"s3://crabby-images/bcce7/bcce75bb02fa521444092f9556688404bba0fd67" alt="" [data:image/s3,"s3://crabby-images/cad08/cad080b249cdbf55e95ece90e125aba90fc1c4f7" alt=""](https://godoc.org/github.com/gofiber/fiber) data:image/s3,"s3://crabby-images/1a112/1a11200ba93cb314279a67d4a914a0075a68e437" alt=""
|
||||
[data:image/s3,"s3://crabby-images/278a5/278a5eb5c59913bc0bfd456a47786d36a4ec754c" alt=""](https://github.com/gofiber/fiber/releases) data:image/s3,"s3://crabby-images/bcce7/bcce75bb02fa521444092f9556688404bba0fd67" alt="" [data:image/s3,"s3://crabby-images/cad08/cad080b249cdbf55e95ece90e125aba90fc1c4f7" alt=""](https://godoc.org/github.com/gofiber/fiber) data:image/s3,"s3://crabby-images/1a112/1a11200ba93cb314279a67d4a914a0075a68e437" alt=""
|
||||
|
||||
**[Fiber](https://github.com/gofiber/fiber)** is an **[Express](https://expressjs.com/en/4x/api.html)** styled HTTP framework implementation running on **[Fasthttp](https://github.com/valyala/fasthttp)**, the **fastest** HTTP engine for **[Go](https://golang.org/doc/)**. The package make use of similar framework convention as they are in express. People switching from **[Node](https://nodejs.org/en/about/)** to **[Go](https://golang.org/doc/)** often end up in a bad learning curve to start building their webapps, this project is meant to **ease** things up for **fast** development, but with **zero memory allocation** and **performance** in mind. See **[API Documentation](https://gofiber.github.io/fiber/)**
|
||||
<img align="right" height="180px" src="https://gofiber.github.io/fiber/static/logo.jpg" />
|
||||
|
||||
**[Fiber](https://github.com/gofiber/fiber)** is an [Express](https://expressjs.com/en/4x/api.html)-styled HTTP web framework implementation running on [Fasthttp](https://github.com/valyala/fasthttp), the **fastest** HTTP engine for Go (Golang). The package make use of similar framework convention as they are in Express.
|
||||
|
||||
People switching from [Node.js](https://nodejs.org/en/about/) to [Go](https://golang.org/doc/) often end up in a bad learning curve to start building their webapps, this project is meant to **ease** things up for **fast** development, but with **zero memory allocation** and **performance** in mind.
|
||||
|
||||
📚 See **[API Documentation](https://gofiber.github.io/fiber/)**.
|
||||
|
||||
[data:image/s3,"s3://crabby-images/b7f9f/b7f9fe04f5eaaa3a51f82eedc6e19d5c3b51d7a2" alt=""](https://gofiber.github.io/fiber/#/benchmarks)
|
||||
**[Click here to see all benchmark results](https://gofiber.github.io/fiber/#/benchmarks)**
|
||||
|
||||
👉 **[Click here](https://gofiber.github.io/fiber/#/benchmarks)** to see all benchmark results.
|
||||
|
||||
## Features
|
||||
* Optimized for speed and low memory usage.
|
||||
|
||||
* Optimized for speed and low memory usage
|
||||
* Rapid Server-Side Programming
|
||||
* Easy routing with parameters
|
||||
* Static files with custom prefix
|
||||
* Middleware with Next support
|
||||
* Express API endpoints
|
||||
* **[API Documentation](https://gofiber.github.io/fiber/)**
|
||||
* [Comprehensible documentation](https://gofiber.github.io/fiber/)
|
||||
|
||||
## Installing
|
||||
Assuming you’ve already installed **[Go](https://golang.org/doc/)**, install the **[Fiber](https://github.com/gofiber/fiber)** package by calling the following command:
|
||||
```bash
|
||||
|
||||
Assuming you’ve already installed Go `1.11+` 😉
|
||||
|
||||
Install the [Fiber](https://github.com/gofiber/fiber) package by calling the following command:
|
||||
|
||||
```console
|
||||
$ go get -u github.com/gofiber/fiber
|
||||
```
|
||||
|
||||
## Hello world
|
||||
## Hello, world!
|
||||
|
||||
Embedded below is essentially the simplest Fiber app you can create.
|
||||
```bash
|
||||
$ create server.go
|
||||
```
|
||||
|
||||
```go
|
||||
// server.go
|
||||
|
||||
package main
|
||||
|
||||
import "github.com/gofiber/fiber"
|
||||
|
||||
func main() {
|
||||
// Create new Fiber instance
|
||||
app := fiber.New()
|
||||
|
||||
// Create new route with GET method
|
||||
app.Get("/", func(c *fiber.Ctx) {
|
||||
c.Send("Hello, World!")
|
||||
})
|
||||
|
||||
|
||||
// Start server on http://localhost:8080
|
||||
app.Listen(8080)
|
||||
}
|
||||
```
|
||||
```bash
|
||||
|
||||
Go to console and run:
|
||||
|
||||
```console
|
||||
$ go run server.go
|
||||
```
|
||||
Browse to **http://localhost:8080** and you should see `Hello, World!` on the page.
|
||||
|
||||
And now, browse to **http://localhost:8080** and you should see `Hello, World!` on the page! 🎉
|
||||
|
||||
## Static files
|
||||
|
||||
To serve static files, use the [Static](https://gofiber.github.io/fiber/#/?id=static-files) method.
|
||||
|
||||
```go
|
||||
package main
|
||||
|
||||
import "github.com/gofiber/fiber"
|
||||
|
||||
func main() {
|
||||
// Create new Fiber instance
|
||||
app := fiber.New()
|
||||
|
||||
|
||||
// Serve all static files on ./public folder
|
||||
app.Static("./public")
|
||||
|
||||
|
||||
// Start server on http://localhost:8080
|
||||
app.Listen(8080)
|
||||
}
|
||||
```
|
||||
|
||||
Now, you can load the files that are in the public directory:
|
||||
```shell
|
||||
|
||||
```console
|
||||
http://localhost:8080/hello.html
|
||||
http://localhost:8080/js/jquery.js
|
||||
http://localhost:8080/js/script.js
|
||||
http://localhost:8080/css/style.css
|
||||
```
|
||||
|
||||
## Middleware
|
||||
Middleware has never been so easy, just like express you call the Next() matching route function!
|
||||
|
||||
Middleware has never been so easy, just like Express you call the `Next()` matching route function!
|
||||
|
||||
```go
|
||||
package main
|
||||
|
||||
import "github.com/gofiber/fiber"
|
||||
|
||||
func main() {
|
||||
// Create new Fiber instance
|
||||
app := fiber.New()
|
||||
|
||||
// Define all used middlewares in Use()
|
||||
|
||||
app.Use(func(c *fiber.Ctx) {
|
||||
c.Write("Match anything!\n")
|
||||
c.Next()
|
||||
})
|
||||
|
||||
app.Use("/api", func(c *fiber.Ctx) {
|
||||
c.Write("Match starting with /api\n")
|
||||
c.Next()
|
||||
})
|
||||
|
||||
app.Get("/api/user", func(c *fiber.Ctx) {
|
||||
c.Write("Match exact path /api/user\n")
|
||||
})
|
||||
|
||||
|
||||
|
||||
// Start server on http://localhost:8080
|
||||
app.Listen(8080)
|
||||
}
|
||||
```
|
||||
|
||||
## API Documentation
|
||||
We created an extended API documentation including examples, **[click here](https://gofiber.github.io/fiber/)**
|
||||
|
||||
We created an extended API documentation including examples, **[click here](https://gofiber.github.io/fiber/)**.
|
||||
|
||||
|
||||
## Stargazers over time
|
||||
|
||||
[data:image/s3,"s3://crabby-images/7ff34/7ff34564df54fa6223db45fe1dfcdb6a30c300b3" alt="Stargazers over time"](https://starchart.cc/gofiber/fiber)
|
||||
|
||||
## License
|
||||
gofiber/fiber is free and open-source software licensed under the [MIT License](https://github.com/gofiber/fiber/edit/master/LICENSE).
|
||||
|
||||
|
||||
☝️ _Please note:_ `gofiber/fiber` is free and open-source software licensed under the [MIT License](https://github.com/gofiber/fiber/edit/master/LICENSE).
|
||||
|
||||
*Caught a mistake? [Edit this page on GitHub!](https://github.com/gofiber/fiber/blob/master/README.md)*
|
||||
|
Loading…
x
Reference in New Issue
Block a user