Gin(一):Hello Gin

https://juejin.im/post/5d2af41ee51d45775d517020

更多文章 狂点 -> ISLAND

什么是 Gin

Gin 是一个用 Golang 写的 http web 框架。

这是来自 Gin Github 上的描述。

开发环境

  • GoLand 2019.2 EAP
  • GoLang 1.11.5
  • 采用 Go Modules 进行管理

快速入门

GoLand 新建项目的时候,我们选择 Go Modules(vgo) ,填写我们的项目地址和项目名称,我们命名为 GinHello

新建项目

点击 Create ,此时 Goland 为我们生成了项目目录,Go 项目的目录永远是那么的简单,比 JavaMaven 或者 Gradle 生成的项目目录简单多了。

  1. GinHello
  2. |
  3. |-go.mod

对,就是一个文件 ,一个 Go module 文件。go modGo 官方引入的一个依赖管理工具。

添加依赖

通过 go mod 文件进行依赖的。

require github.com/gin-gonic/gin v1.4.0

我们把上面的依赖进行添加到 go module 中, goLand 会自动帮我们进行依赖的下载和管理。

Hello Gin

当完成依赖的添加,就可以开始写代码了。

新建一个 main.go 文件。

  1. package main
  2. import (
  3. "github.com/gin-gonic/gin"
  4. )
  5. func main() {
  6. router := gin.Default()
  7. router.Run()
  8. }

Gin 只需要两行代码就可以把我们的服务跑起来。

我们只要点击运行,项目便会启动一个 8080 端口,打开浏览器 localhost:8080 我们便可以看到页面上提示出 404 page not found ,这是因为我们的根路由上并没有返回任何结果。同时我们可以在控制台上看到一些打印信息,其中就包括我们刚刚访问根路由的端口。

产生接口

项目已经启动了,那么如何返回一个接口呢?

通过 routerHandle 进行配置我们返回的参数。

  1. // 省略代码
  2. // 添加 Get 请求路由
  3. r.GET("/", func(context *gin.Context) {
  4. context.String(http.StatusOK, "hello gin")
  5. })
  6. // 省略代码

此时我们重启项目,重新访问页面 localhost:808,此刻的页面上已经显示了 hello gin

同样,我们还可以进行 POST,PUT,DELETE等请求方式。

单元测试

单元测试是项目不能缺少的模块,也是保障项目可以正常运行的重要依赖。下面就对 Gin 进行单元测试。

为了方便单元测试,我们首先要对我们的项目进行一下抽取。

新建立一个文件夹叫做 initRouter

建立 go 文件 initRouter.go

  1. package initRouter
  2. import (
  3. "github.com/gin-gonic/gin"
  4. "net/http"
  5. )
  6. func SetupRouter() *gin.Engine {
  7. router := gin.Default()
  8. // 添加 Get 请求路由
  9. router.GET("/", func(context *gin.Context) {
  10. context.String(http.StatusOK, "hello gin")
  11. })
  12. return router
  13. }

同时修改 main.go

  1. package main
  2. import (
  3. "GinHello/initRouter"
  4. )
  5. func main() {
  6. router := initRouter.SetupRouter()
  7. _ = router.Run()
  8. }

完成了项目测试的初步建立。

建立 test 目录, golang 的单元测试都是以 _test 结尾,建立 index_test.go 文件。

  1. package test
  2. import (
  3. "GinHello/initRouter"
  4. "github.com/stretchr/testify/assert"
  5. "net/http"
  6. "net/http/httptest"
  7. "testing"
  8. )
  9. func TestIndexGetRouter(t *testing.T) {
  10. router := initRouter.SetupRouter()
  11. w := httptest.NewRecorder()
  12. req, _ := http.NewRequest(http.MethodGet, "/", nil)
  13. router.ServeHTTP(w, req)
  14. assert.Equal(t, http.StatusOK, w.Code)
  15. assert.Equal(t, "hello gin", w.Body.String())
  16. }

通过 assert 进行断言,来判断返回状态码和返回值是否与代码中的值一致。

此时的项目目录为:

  1. GinHello
  2. |
  3. |-initRouter
  4. | |-initRouter.go
  5. |
  6. |-test
  7. | |-index_test.go
  8. |
  9. |-main.go
  10. |-go.mod
  11. |-go.sum

运行单元测试,控制台打印出单元测试结果。

—- PASS: TestIndexGetRouter (0.02s)
PASS

总结

通过简单的搭建一个 Gin 项目,可以看到 Go 语言搭建一个 Http 服务器很简单,也很方便,零配置即可完成项目并运行起来。

本章节代码

https://github.com/youngxhui/GinHello

ft_authoradmin  ft_create_time2019-07-31 14:38
 ft_update_time2019-07-31 14:39