從本章節開始的2個章節基本都是gin的核心知識點,如果您是初學者,建議只看 基礎用法 ,先學會使用是最重要的。
當使用熟練后,再回頭看 進階學習 ,你會徹底明白其中原理,進階學習都是gin源碼解析,對初學者來說難度比較大。
基礎用法
1.創建一個標準的路由與路由組
```
// 使用 gin 路由包提供的默認路由創建一個路有引擎
router := gin.Default()
// 創建一個路由組,并基于路由組創建具體路由
backend:=router.Group("/api/v1")
// 使用已有路由組可以繼續分組
users:=backend.Group("/users")
// 這里的花括號,只是為了讓代碼塊緊湊,沒有其他任何含義,和 c、c++ 語言的語法塊完全一樣.
{
// 對于初學者,這里比較難理解的就是第二個參數。
// 這里您首先知道它是從容器獲取了一個表單參數驗證器,校驗客戶端請求的參數就行
// 具體細節在表單參數驗證器做專門介紹
users.GET("list", validatorFactory.Create(consts.ValidatorPrefix+"UsersList"))
users.POST("create", validatorFactory.Create(consts.ValidatorPrefix+"UsersCreate"))
users.POST("edit", validatorFactory.Create(consts.ValidatorPrefix+"UsersEdit"))
users.POST("destroy", validatorFactory.Create(consts.ValidatorPrefix+"UsersDestroy"))
}
```
2.帶中間件的路由(組)
實際項目開發中,有一部分接口是開放的,但是有部分是需要鑒權認證的,那么針對需要鑒權認證的所有路由可以統一添加中間件進行鑒權認證,一般是token認證。
```
// 針對以上用戶組路由添加token中間件鑒權認證
// 創建一個理由組,并基于路由組創建具體路由
backend:=router.Group("/api/v1")
// authorization.CheckTokenAuth() 是 ginskeleton 默認集成校驗token的中加減,直接使用即可
// backend 加載了中間件,表示 /api/v1 開頭的路由全部需要 token 校驗
backend.Use(authorization.CheckTokenAuth()) //A
users:=backend.Group("/users")
// users 加載了中間件,表示 /api/v1/users 開頭的路由全部需要 token 校驗
users.Use(authorization.CheckTokenAuth()) // B, 注意: B 和 A 存在重復校驗token,實際使用時不要重復驗證,如果在 A 處加載,那么就取消 B 處的加載中間件的邏輯
{
// 接下來定義具體路由(路徑),對于初學者,這里比較難理解的就是第二個參數。
// 首先告訴各位這里是從容器獲取了一個表單參數驗證器,校驗客戶端請求的參數
// 具體細節在表單參數驗證器做專門介紹
users.GET("list", validatorFactory.Create(consts.ValidatorPrefix+"UsersList"))
users.POST("create", validatorFactory.Create(consts.ValidatorPrefix+"UsersCreate"))
users.POST("edit", validatorFactory.Create(consts.ValidatorPrefix+"UsersEdit"))
users.POST("destroy", validatorFactory.Create(consts.ValidatorPrefix+"UsersDestroy"))
}
```
3.不帶中間件、不帶參數驗校驗器的路由
驗證碼路由,該路由無需專門校驗參數,所以可以直接調用控制器
進階學習
4.路由、中間件相關的 gin 源碼學習
看到這里我相信您已經學會了路由、路由組、中間件的創建與使用,那么更深入一步。
我們一起研究一下 users.GET("list", 參數2) 背后究竟發生了什么
當我們明白回調函數的本質以后,那么下面的代碼理解起來,就是非常簡單的一件事情了
以上過程總體上就是在定義路由組、路由路徑、然后給路由路徑編寫各種回調函數,一個路由路徑可以對應很多個回調函數,具體數量我們將在下一章節繼續分析源碼。
5.路由組、中間鍵、路由 各自的特點
5.1 路由組相關的gin源碼
針對以上源碼總結一下:
api := router.Group("/api/") 只有使用 Group 函數創建出來的路由組可以繼續創建更多路由組,一旦基于路由組調用了其他函數獲取的結果,就只能去定義具體路由、加載中間件等,相關示例:
5.2中間件源碼定義
5.3 路由背后的源碼
學習到這里,再給大家看一段如下代碼,我想大家瞬間就懂了。
對于初學者,關于第二個參數我們會在后續繼續介紹,這里只要知道他本質上也是一個 func (c \*gin.Conetxt) { } 即可。
- Golang
- Beego框架
- Gin框架
- gin框架介紹
- 使用Gin web框架的知名開源線上項目
- go-admin-gin
- air 熱啟動
- 完整的form表單參數驗證語法
- Go 語言入門練手項目推薦
- Golang是基于多線程模型
- golang 一些概念
- Golang程序開發注意事項
- fatal error: all goroutines are asleep - deadlock
- defer
- Golang 的內建調試器
- go部署
- golang指針重要性
- 包(golang)
- Golang框架選型比較: goframe, beego, iris和gin
- GoFrame
- golang-admin-項目
- go module的使用方法及原理
- go-admin支持多框架的后臺系統(go-admin.cn)
- docker gocv
- go-fac
- MSYS2
- 企業開發框架系統推薦
- gorm
- go-zero
- 優秀系統
- GinSkeleton(gin web 及gin 知識)
- 一次 request -> response 的生命周期概述
- 路由與路由組以及gin源碼學習
- 中間件以及gin源碼學習
- golang項目部署
- 獨立部署golang
- 代理部署golang
- 容器部署golang
- golang交叉編譯
- goravel
- kardianos+gin 項目作為windows服務運行
- go env
- 適用在Windows、Linux和macOS環境下打包Go應用程序的詳細步驟和命令
- Redis
- Dochub
- Docker部署開發go環境
- Docker部署運行go環境
- dochub說明
- Vue
- i18n
- vue3
- vue3基本知識
- element-plus 表格單選
- vue3后臺模板
- Thinkphp
- Casbin權限控制中間件
- 容器、依賴注入、門面、事件、中間件
- tp6問答
- 偽靜態
- thinkphp-queue
- think-throttle
- thinkphp隊列queue的一些使用說明,queue:work和queue:listen的區別
- ThinkPHP6之模型事件的觸發條件
- thinkphp-swoole
- save、update、insert 的區別
- Socket
- workerman
- 介紹
- 從ThinkPHP6移植到Webman的一些技術和經驗(干貨)
- swoole
- swoole介紹
- hyperf
- hf官網
- Swoft
- swoft官網
- easyswoole
- easyswoole官網地址
- EASYSWOOLE 聊天室DEMO
- socket問答
- MySQL
- 聚簇索引與非聚簇索引
- Mysql使用max獲取最大值細節
- 主從復制
- 隨機生成20萬User表的數據
- MySQL進階-----前綴索引、單例與聯合索引
- PHP
- 面向切面編程AOP
- php是單線程的一定程度上也可以看成是“多線程”
- PHP 線程,進程、并發、并行 的理解
- excel數據畫表格圖片
- php第三方包
- monolog/monolog
- league/glide
- 博客-知識網站
- php 常用bc函數
- PHP知識點的應用場景
- AOP(面向切面編程)
- 注解
- 依賴注入
- 事件機制
- phpspreadsheet導出數據和圖片到excel
- Hyperf
- mineAdmin
- 微服務
- nacos注冊服務
- simps-mqtt連接客戶端simps
- Linux
- 切換php版本
- Vim
- Laravel
- RabbitMQ
- thinkphp+rabbitmq
- 博客
- Webman框架
- 框架注意問題
- 關于內存泄漏
- 移動端自動化
- 懶人精靈
- 工具應用
- render
- gitlab Sourcetree
- ssh-agent失敗 錯誤代碼-1
- 資源網站
- Git
- wkhtmltopdf
- MSYS2 介紹
- powershell curl 使用教程
- NSSM(windows服務工具)
- MinGW64
- 知識擴展
- 對象存儲系統
- minio
- 雪花ID
- 請求body參數類型
- GraphQL
- js 深拷貝
- window 共享 centos文件夾
- 前端get/post 請求 特殊符號 “+”傳參數問題
- 什么是SCM系統?SCM系統與ERP系統有什么區別?
- nginx 日志格式統一為 json
- 特殊符號怎么打
- 收藏網址
- 收藏-golang
- 收藏-vue3
- 收藏-php
- 收藏-node
- 收藏-前端
- 規劃ITEM
- 旅游類
- 人臉識別
- dlib
- Docker&&部署
- Docker-compose
- Docker的網絡模式
- rancher
- DHorse
- Elasticsearch
- es與kibana都docke連接
- 4種數據同步到Elasticsearch方案
- GPT
- 推薦系統
- fastposter海報生成
- elasticsearch+logstash+kibana
- beego文檔系統-MinDoc
- jeecg開源平臺
- Java
- 打包部署
- spring boot
- 依賴
- Maven 相關 命令
- Gradle 相關命令
- mybatis
- mybatis.plus
- spring boot 模板引擎
- SpringBoot+Maven多模塊項目(創建、依賴、打包可執行jar包部署測試)完整流程
- Spring Cloud
- Sentinel
- nacos
- Apollo
- java推薦項目
- gradle
- Maven
- Nexus倉庫管理器
- Python
- Masonite框架
- scrapy
- Python2的pip2
- Python3 安裝 pip3
- 安全攻防
- 運維技術
- 騰訊云安全加固建議
- 免費freessl證書申請
- ruby
- homeland
- Protobuf
- GIT
- FFMPEG
- 命令說明
- 音頻
- ffmpeg合并多個MP4視頻
- NODEJS
- 開發npm包
- MongoDB
- php-docker-mongodb環境搭建
- mongo基本命令
- Docker安裝MongoDB最新版并連接
- 少兒編程官網
- UI推薦
- MQTT
- PHP連接mqtt
- EMQX服務端
- php搭建mqtt服務端