goft
  • gin脚手架使用文档
  • 所需环境
  • 建议的目录结构
  • 配置
  • 最简单的启动代码
  • 出错跟踪
  • 自定义错误展示
  • 覆盖系统内置异常处理
  • 路由
    • 路由写在一个文件里
    • 常规设置
  • 控制器
    • 控制器形式
    • 控制器方法
    • 控制器方法不想返回值
    • 输出JSON
    • 获取请求对象
  • 全局中间件
    • 基本定义
    • 注册中间件
    • 示例1:判断token参数
    • 示例2:修改响应内容
    • 跨域中间件
  • 路由级中间件
    • 基本定义
    • 示例:参数验证和业务分离
  • 依赖注入
    • 基本定义
    • 注册依赖配置
    • 基本使用
    • 注入Gorm和XOrm
  • 精简版领域驱动
    • 基本说明和概念
    • 基本分层
    • 领域层
    • 领域层之实体
    • 领域层之值对象
    • 领域层之仓储
    • 领域层之聚合
    • 领域服务层
    • 应用层(application)
    • 应用层之DTO
    • DTO和实体映射
    • 应用层之应用服务层
    • 代码落地
由 GitBook 提供支持
在本页
  • 接口定义
  • 创建全局中间件

这有帮助吗?

  1. 全局中间件

基本定义

gin里面本身就有中间件,脚手架里对中间件做了简单的封装

接口定义

type Fairing interface {

OnRequest(*gin.Context) error

OnResponse(result interface{}) (interface{}, error)

}

OnRequest: 执行控制器方法前,修改如头信息、判断参数等等

OnResponse:执行控制器方法后。可以修改返回值内容

创建全局中间件

其实就是一个Struct 如

type TokenCheck struct {}
func NewTokenCheck() *TokenCheck {
   return &TokenCheck{}
}
func(this *TokenCheck) OnRequest(ctx *gin.Context) error{
      return nil
}
func(this *TokenCheck) OnResponse(result interface{}) (interface{}, error){
   return result,nil  
}

注意点:两个方法必须都有返回值。

上一页获取请求对象下一页注册中间件

最后更新于4年前

这有帮助吗?