Golang语言 Gin框架环境配置、报错处理、接口调用、配置和日志管理|Go主题月

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 下载并安装go get -u github.com/gin-gonic/gin安装失败的话,直接打开 github.com/gin-gonic/gin,下载压缩包,并在GOPATH路径的src目录下面建立github.com,解压到这个目录下面

1.JPG

安装:


下载并安装


go get -u github.com/gin-gonic/gin

安装失败的话,直接打开 github.com/gin-gonic/gin,下载压缩包,并在GOPATH路径的src目录下面建立github.com,解压到这个目录下面;


2.JPG


遇到的报错信息:



Go 项目编译:cannot find package "." in:*

将缺少依赖的包重新安装一次即可解决问题。

go: inconsistent vendoring in xxx报错


3.JPG


修改GOPAHT,改到非GOROOT路径。GOROOT是GO语言安装路径,GOPATH是GO语言编译环境所需路径,因此二者不能为同一路径


4.JPG


新建项目



GOPATH目录下面的src下面新建一个文件夹app,使用命令

go mod init


新建 main.go,写出我们的第一个程序


package main
import "github.com/gin-gonic/gin"
func main() {
    r := gin.Default()
    r.GET("/", func(c *gin.Context) {
        c.JSON(200, gin.H{
            "name": "叫我詹躲躲",
            "gend": "男",
        })
    })
    r.Run(":8080")
}

运行程序

go run main.go

5.JPG


浏览器运行:

6.JPG

生成JSON



func AsciiJSON() {
    r := gin.Default()
    r.GET("/", func(c *gin.Context) {
        c.JSON(200, gin.H{
            "name": "叫我詹躲躲",
            "gend": "男",
        })
    })
    r.Run(":8080")
}


调用



package main
import (
    "app/function"
    "github.com/gin-gonic/gin"
)
func main() {
    //使用AsciiJSON生成带有转义的非ASCII字符的纯ASCII JSON。
    function.AsciiJSON()
}

7.JPG

测试get请求



绑定表单数据请求与自定义结构


//绑定表单数据请求与自定义结构
type StructA struct {
    FieldA string `form:"field_a"`
}
type StructB struct {
    NestedStruct StructA
    FieldB       string `form:"field_b"`
}
//get请求
func GetFormData(c *gin.Context) {
    var b StructB
    c.Bind(&b)
    c.JSON(200, gin.H{
        "a": b.NestedStruct,
        "b": b.FieldB,
    })
}

调用


package main
import (
    "app/function"
    "github.com/gin-gonic/gin"
)
func main() {
    //将表单数据请求与自定义结构绑定
    r := gin.Default()
    //测试get请求
    r.GET("/getFormData", function.GetFormData)
    r.Run()
}

8.JPG


查询返回信息


//绑定查询字符串或发布数据
type PersonInfo struct {
    Name    string `form:"name"`
    Address string `form:"address"`
    Memo    string `form:"memo"`
}
//返回信息
func QueryInfo(c *gin.Context) {
    var person PersonInfo
    if c.ShouldBind(&person) == nil {
        log.Println(person.Name)
        log.Println(person.Address)
        log.Println(person.Memo)
    }
    c.String(200, "Success")
}


调用


9.JPG

package main
import (
    "app/function"
    "github.com/gin-gonic/gin"
)
func main() {
    r := gin.Default()
    //查询返回信息
    r.GET("/queryInfo", function.QueryInfo)
    r.Run()
}


自定义HTTP配置



http.ListenAndServe(":8080", router)


或者


s := &http.Server{
    Addr:           ":8080",
    Handler:        router,
    ReadTimeout:    10 * time.Second,
    WriteTimeout:   10 * time.Second,
    MaxHeaderBytes: 1 << 20,
}
s.ListenAndServe()


自定义日志文件



router := gin.New()
router.Use(gin.LoggerWithFormatter(func(param gin.LogFormatterParams) string {
    return fmt.Sprintf("%s - [%s] \"%s %s %s %d %s \"%s\" %s\"\n",
            param.ClientIP,
            param.TimeStamp.Format(time.RFC1123),
            param.Method,
            param.Path,
            param.Request.Proto,
            param.StatusCode,
            param.Latency,
            param.Request.UserAgent(),
            param.ErrorMessage,
    )
}))
router.Use(gin.Recovery())
router.GET("/ping", func(c *gin.Context) {
    c.String(200, "pong")
})
router.Run(":8080
相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
15天前
|
存储 Go 索引
go语言中数组和切片
go语言中数组和切片
26 7
|
15天前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。
|
15天前
|
程序员 Go
go语言中结构体(Struct)
go语言中结构体(Struct)
92 71
|
14天前
|
存储 Go 索引
go语言中的数组(Array)
go语言中的数组(Array)
100 67
|
17天前
|
Go 索引
go语言for遍历数组或切片
go语言for遍历数组或切片
88 62
|
19天前
|
并行计算 安全 Go
Go语言中的并发编程:掌握goroutines和channels####
本文深入探讨了Go语言中并发编程的核心概念——goroutine和channel。不同于传统的线程模型,Go通过轻量级的goroutine和通信机制channel,实现了高效的并发处理。我们将从基础概念开始,逐步深入到实际应用案例,揭示如何在Go语言中优雅地实现并发控制和数据同步。 ####
|
15天前
|
存储 Go
go语言中映射
go语言中映射
32 11
|
17天前
|
Go
go语言for遍历映射(map)
go语言for遍历映射(map)
29 12