前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Golang快速开发框架——新增统一消息处理模块(七)

Golang快速开发框架——新增统一消息处理模块(七)

作者头像
cn華少
发布2022-03-04 13:22:39
3240
发布2022-03-04 13:22:39
举报
文章被收录于专栏:IT综合技术分享

Golang快速开发框架——新增统一消息处理模块(七)

背景

知识分享之Golang篇是我在日常使用Golang时学习到的各种各样的知识的记录,将其整理出来以文章的形式分享给大家,来进行共同学习。欢迎大家进行持续关注。

知识分享系列目前包含Java、Golang、Linux、Docker等等。

开发环境

  • 系统:windows10
  • 语言:Golang
  • golang版本:1.17
  • 代码仓库:FastDevelopGo

内容

日常我们使用golang开发项目时经常需要使用一些基础组件,每次新建较为繁琐,现有市面上的感觉不太适合自己,因此决定自己搭建一套,同时开源出来分享给大家使用,欢迎大家提出各种需求。 下面我们开始对于该框架进行继续完善,本节我们要完成的需求是:

  • 新增统一消息处理模块

1、新增错误处理工具类和相关结构体

代码语言:javascript
复制
package mess

import "strings"

// RetMessage 主消息结构体
type RetMessage struct {
    Code string      `json:"code"`
    Msg  string      `json:"msg"`
    Data interface{} `json:"data"`
}

// ReturnReqMess 常规消息生成函数
func ReturnReqMess(code, msg string, data interface{}) *RetMessage {
    mess := RetMessage{
        Code: code,
        Msg:  msg,
        Data: data,
    }
    return &mess
}

// ResErrMess 异常消息生成函数
// msg 可以增加多个提示信息
func ResErrMess(code string, msg ...string) *RetMessage {
    return &RetMessage{code, strings.Join(msg, ""), nil}
}

// ResMessOK 成功消息返回通用函数
// data 返回的结构对象
func ResMessOK(data interface{}) *RetMessage {
    return &RetMessage{"0", "成功", data}
}

2、编写测试demo

代码语言:javascript
复制
// 测试网关
func testRouter(r *gin.Engine) {
    // 测试500中间件地址
    r.GET("/demo", func(c *gin.Context) {
        a := c.DefaultQuery("a", "1")
        i, _ := strconv.Atoi(a)
        // 当a参数是默认值1时会报错
        x := 0 / (1 - i)
        log.Println(x)
        c.JSON(http.StatusInternalServerError, fmt.Errorf("测试异常"))
    })

    // 测试-成功消息,常规赋值方式
    r.GET("/mess", func(c *gin.Context) {
        data := []string{
            "测试用户", "12岁", "男",
        }
        // 返回成功消息
        c.JSON(http.StatusOK, mess.ReturnReqMess("0", "成功", data))
    })
    // 测试-成功消息
    r.GET("/messOK", func(c *gin.Context) {
        data := []string{
            "测试用户002", "20岁", "女",
        }
        // 返回成功消息
        c.JSON(http.StatusOK, mess.ResMessOK(data))
    })
    // 测试-成功消息,常规赋值方式
    r.GET("/messErr", func(c *gin.Context) {
        // 返回成功消息
        c.JSON(http.StatusOK, mess.ResErrMess("1001011", "常规业务错误:", "用户名或密码错误"))
    })
}

测试结果如下:

image.png

image.png

image.png

注: 这个框架我的初步想法时后续增加可视化页面、代码快速生成模块、项目框架快速生成模块等等,有其他需求想法的小伙伴欢迎在评论区留言或直接到代码仓库中提出宝贵的issue

欢迎大家积极start,大家的关注是我最大的动力。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022.01.20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Golang快速开发框架——新增统一消息处理模块(七)
    • 背景
      • 开发环境
        • 内容
          • 1、新增错误处理工具类和相关结构体
          • 2、编写测试demo
      相关产品与服务
      消息队列 TDMQ
      消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档