从本章节开始的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服务端