```go
func main() {
// 新建一個沒有任何默認中間件的路由
r := gin.New()
// 全局中間件
// Logger 中間件將日志寫入 gin.DefaultWriter,即使你將 GIN_MODE 設置為 release。
// By default gin.DefaultWriter = os.Stdout
r.Use(gin.Logger())
// Recovery 中間件會 recover 任何 panic。如果有 panic 的話,會寫入 500。
r.Use(gin.Recovery())
// 你可以為每個路由添加任意數量的中間件。
r.GET("/benchmark", MyBenchLogger(), benchEndpoint)
// 認證路由組
// authorized := r.Group("/", AuthRequired())
// 和使用以下兩行代碼的效果完全一樣:
authorized := r.Group("/")
// 路由組中間件! 在此例中,我們在 "authorized" 路由組中使用自定義創建的
// AuthRequired() 中間件
authorized.Use(AuthRequired())
{
authorized.POST("/login", loginEndpoint)
authorized.POST("/submit", submitEndpoint)
authorized.POST("/read", readEndpoint)
// 嵌套路由組
testing := authorized.Group("testing")
testing.GET("/analytics", analyticsEndpoint)
}
// 監聽并在 0.0.0.0:8080 上啟動服務
r.Run(":8080")
}
```
- 介紹
- 快速入門
- 基準測試
- 特性
- Jsoniter
- 示例
- AsciiJSON
- HTML 渲染
- HTTP2 server 推送
- JSONP
- Multipart/Urlencoded 綁定
- Multipart/Urlencoded 表單
- PureJSON
- Query 和 post form
- SecureJSON
- XML/JSON/YAML/ProtoBuf 渲染
- 上傳文件
- 單文件
- 多文件
- 不使用默認的中間件
- 從 reader 讀取數據
- 優雅地重啟或停止
- 使用 BasicAuth 中間件
- 使用 HTTP 方法
- 使用中間件
- 只綁定 url 查詢字符串
- 在中間件中使用 Goroutine
- 多模板
- 如何記錄日志
- 定義路由日志的格式
- 將 request body 綁定到不同的結構體中
- 支持 Let's Encrypt
- 映射查詢字符串或表單參數
- 查詢字符串參數
- 模型綁定和驗證
- 綁定 HTML 復選框
- 綁定 Uri
- 綁定查詢字符串或表單數據
- 綁定表單數據至自定義結構體
- 自定義 HTTP 配置
- 自定義中間件
- 自定義驗證器
- 設置和獲取 Cookie
- 路由參數
- 路由組
- 運行多個服務
- 重定向
- 靜態文件服務
- 靜態資源嵌入
- 測試
- 用戶
- FAQ