跟着官网学Go之基于Gin开发一个简单的RESTful API
前面已经将Go1.17.6
安装好了,这一小节,继续跟着官网学习基于Gin开发RESTful API
环境准备
这里,我在E盘新建一个名为ginrest
的文件夹,然后用vscode
打开该文件夹,继续使用cmd命令进入到E:\ginrest
文件夹,然后执行go mod init
命令
此时,在该文件夹下回生成一个名为go.mod
的文件
新建main.go
前面基础准备好后,我们就需要准备程序该有的入口,那便是新建一个main.go
文件,
在该文件中加入包名package main
我继续新建一个名为album
的struct
,go中的struct
类似于C#中的类,在Go中,定义一个struct
的标准格式如下
1 | type 名 struct{ |
我们在该struct
中加入一些字段属性
1 | type album struct { |
我们可以看到类型后面用
json
标识了别名,其主要作用则是当该struct
序列化成json时,会序列化为该别名,如果没有别名则按属性名展示。
我新建一个album
的数组,主要是为后续数据读取做准备
1 | var albums = []album{ |
使用Gin
前面把基础的准备工作已经做好了,现在便是进入主题,开始使用Gin
,引入Gin
包,现在main.go
中使用import
导入包并编写main方法,在main方法中使用gin
创建一个简单的Http服务器
1 | import "github.com/gin-gonic/gin" |
这里是0.0.0.0:8080
是监听本机的8080
端口,其实也可以直接使用:8080
,如:router.Run(":8080")
,端口号可以自行调整,如果不指定,默认端口号也是8080
。此时通过cmd执行go get .
来下载gin
的依赖包,这是不是类似.Net
里面的Nuget
包管理呢?
依赖包下载完成后,此时,我们的go.mod
文件便会新增一来记录,并且会多出一个go.sum
的文件,它为我们记录了依赖包版本信息。
此时,我们的程序就可以运行了,
这是,我们访问一下8080
端口,服务端会返回404 page not found
,那是因为我们现在什么都还没有做,
我们继续来分别实现获取(getAlbums)
和添加(postAlbums)
两个方法,Go语言中的方法和C#有些差别,
C#中大概就是这样子
1 | public List<Albums> GetAlbums(){ |
Go中需要func
关键字来申明,下面就跟着官网的例子继续写
1 | func getAlbums(c *gin.Context) { |
接下来就是将方法注册到Gin
的路由中
1 | router.GET("/albums", getAlbums) |
这里的注册的路由路径都是/albums
,通过Get
和Post
这两种请求方式来区分不同的逻辑
现在运行起来后,在浏览器访问http://localhost:8080/albums
便能正常返回数据
接下来,使用postman
发起post请求,当服务端接受到请求后,会将提交的数据追加到数组中
这里只是使用
Gin
来实现简单的Get
和Post
,就从这个简单的示例中,我们可以感受到它的灵活和简洁,后面我们再继续跟进学习,最好是结合实际例子来做些小应用。
跟着官网学Go之基于Gin开发一个简单的RESTful API