go-zero学习笔记(二)

embedded/2025/2/5 3:14:31/

利用goctl生成api服务

  1. 编写api文件

    //版本信息, import中的版本信息必须与被import的api版本信息一样
    syntax="v1"// 支持引入其他api文件
    // 这在多接口下非常有用
    // 如果不可以引入,对于多接口情况,所有的接口写在同一个文件,很容易造成混乱,阅读和修改也不太方便
    // 支持引入后,可以将接口按照某一规则分组,分文件书写,这样对于后续的阅读修改都较为便利,
    // 搞一个主api文件,将其他文件全部引入即可
    import "***.api"// info 信息 可选
    info(title: "type title here"desc: "type desc here"author: "type author here"email: "type email here"version: "type version here"
    )// 1. 数据类型:基本类型都支持,切片用 []数据类型 表示,也支持map, 指针,以及自定义数据类型
    // 2. 标签:支持json、form、path、header
    //      json:从请求头body中读取数据,一般在post方法中使用
    //      form:从请求的url的参数中读取数据,一般在get方法中使用
    //      path:从请求的url中读取数据,如:ID `path:"id"` 路由定义:/foo/:id  url: /foo/123 会将url中的123读取到
    //      header:从请求的header中读取数据
    // 3. 参数校验规则: 支持optional、options、default、range
    //      optional:当前参数可选,`json:"foo,optional"`
    //      options:当前参数仅可接收的枚举值,枚举值之间用 | 分割,`json:"gender,options=foo|bar"`
    //      default:当前参数默认值,`json:"gender,default=male"`
    //      range:当前参数数值有效范围,仅对数值有效,`json:"age,range=[0:120]"`
    type (GetInfoReq {IDs []string `json:"IDs"`}GetInfoData {ID           string `json:"ID"`Name         string `json:"Name"`MD5          string `json:"md5"`Size         int64  `json:"Size"`Uptime       int64  `json:"uptime"`}GetInfoResp {Data        []*GetInfoData          `json:"data"`Msg         string                  `json:"msg"`Code        int64                   `json:"code"`RequestID   string                  `json:"requestId"`}
    )// 修饰其紧挨的service块,且一个server块只能修饰一个service块
    @server(prefix: api/demo/v1          // url的前缀(可选)group: demo                  // 群组,会在goctl生成的代码的handler、logic中体现(可选)middleware: AuthInterceptor  // 中间件, 多个中间件用逗号分割(可选)// 其他关键字参考gozero官网 https://go-zero.dev/docs/tutorials 、https://go-zero.dev/docs/reference
    )// 服务条目:对单个 HTTP 请求的描述,包括 @doc 语句,handler 语句,路由语句信息
    // 1. @doc 对单个路由的 meta 信息描述,一般为 key-value 值, 传递给 goctl 及其插件来进行扩展生成
    // 2. @handler handlerName 对单个路由的 handler 信息控制,主要用于生成 golang http.HandleFunc 的实现转换方法
    // 3. 路由语句,包括请求方法,请求路径,请求体,响应体信息
    //      请求方法包括:"get"| "head"| "post" | "put" | "patch" | "delete" | "connect" | "options" | "trace"
    //      请求路径 注意参数的标签为path时的呼应 /:id1/:id2...
    //      请求体、响应体可以为空 为空时可以去除括号
    service demo-api {@doc(summary: "信息获取")@handler GetInfoHandlerpost /Info/get (GetInfoReq) returns (GetInfoResp)
    }
    
  2. 执行goctl命令

 goctl api go -api ./api/demo.api -dir . -style gozero
  1. 执行结果
    在这里插入图片描述
    其中:
    etc:静态配置文件目录
    demo.go:程序启动入口文件
    internal:单个服务内部文件,其可见范围仅限当前服务
    config:静态配置文件对应的结构体声明目录
    handler:handler 目录,可选,一般 http 服务会有这一层做路由管理,handler 为固定后缀
    logic:业务目录,所有业务编码文件都存放在这个目录下面,logic 为固定后缀
    svc:依赖注入目录,所有 logic 层需要用到的依赖都要在这里进行显式注入
    types:结构体存放目录

  2. 接下来你只需要负责logic的具体实现就可以了,当前你也可以对生成的内容进行修改


http://www.ppmy.cn/embedded/159639.html

相关文章

嵌入式C语言:大小端详解

目录 一、大小端的概念 1.1. 大端序(Big-endian) 1.2. 小端序(Little-endian) 二、大小端与硬件体系的关系 2.1. 大小端与处理器架构 2.2. 大小端与网络协议 2.3. 大小端对硬件设计的影响 三、判断系统的大小端方式 3.1.…

npm cnpm pnpm npx yarn的区别

npm、cnpm、pnpm、npx、yarn 这几个工具都与 Node.js 项目的包管理和命令执行相关,它们的区别具体如下: 本质与功能定位 npm:是 Node.js 官方的包管理工具,提供了安装、卸载、更新、发布等全方位的包管理功能,还能通…

【数据结构】_C语言实现带头双向循环链表

目录 1. 单链表与双链表 1.1 单链表的结构及结点属性 1.2 双链表的结构及结点属性 2. 单链表与双链表的区别 3. 双链表的实现 3.1 List.h 3.2 List.c 3.3 Test_List.c 注:部分方法的实现细节注释 1. 双链表结点前驱、后继指针域的初始化 2. 各种增、删结…

LabVIEW微位移平台位移控制系统

本文介绍了基于LabVIEW的微位移平台位移控制系统的研究。通过设计一个闭环控制系统,针对微位移平台的通信驱动问题进行了解决,并提出了一种LabVIEW的应用方案,用于监控和控制微位移平台的位移,从而提高系统的精度和稳定性。 项目背…

Spring Boot框架下的单元测试

1. 什么是单元测试 1.1 基本定义 单元测试(Unit Test) 是对软件开发中最小可测单位(例如一个方法或者一个类)进行验证的一种测试方式。在 Java 后端的 Spring Boot 项目中,单元测试通常会借助 JUnit、Mockito 等框架对代码中核心逻辑进行快…

ElasticSearch view

基础知识类 elasticsearch和数据库之间区别? elasticsearch:面向文档,数据以文档的形式存储,即JSON格式的对象。更强调数据的搜索、索引和分析。 数据库:更侧重于事务处理、数据的严格结构化和完整性,适用于…

用Python实现K均值聚类算法

在数据挖掘和机器学习领域,聚类是一种常见的无监督学习方法,用于将数据点划分为不同的组或簇。K均值聚类算法是其中一种简单而有效的聚类算法。今天,我将通过一个具体的Python代码示例,向大家展示如何实现K均值聚类算法&#xff0…

基于微信小程序的酒店管理系统设计与实现(源码+数据库+文档)

酒店管理小程序目录 目录 基于微信小程序的酒店管理系统设计与实现 一、前言 二、系统功能设计 三、系统实现 1、管理员模块的实现 (1) 用户信息管理 (2) 酒店管理员管理 (3) 房间信息管理 2、小程序序会员模块的实现 (1)系统首页 &#xff…