基于Gin框架的web开发,总的来讲有两种:
- 第一种是后端应用go语言模板引擎实现整个web全栈开发,返回残缺的html文件给浏览器。
- 第二种是前后端拆散,应用JSON交互
因为第一种办法消耗太多网络资源,性能差,耦合度高,目前曾经根本被第二种模式取代,这篇博客只介绍如何在Gin框架中返回JSON数据给前端或者挪动端(俗称JSON的渲染)。
生成JSON数据能够用map,也能够用构造体。上面先介绍map:
基于map的JSON数据生成
举个例子,代码如下:
package main
import (
"github.com/gin-gonic/gin"
"net/http"
)
func main() {
r := gin.Default()
r.GET("/json", func(c *gin.Context) {
//这里结构服务器要返回前端的数据,一共有两种办法,第一种是:应用map将数据序列化
//,这个map的key是一个string, value是一个空的接口(这样即能够实现接管任意类型的数据)
data := map[string]interface{}{
"name": "liber",
"message": "hey liber~",
"age": 16,
}
//这里要返回json格局的数据,所以用c.JSON,这样,数据就返回给申请方了
c.JSON(http.StatusOK, data)
})
r.Run(":9090")
}
测试后果如下:
因为用map来序列化json数据是很常见的写法,Gin框架的作者将这种写法封装了一下:
//H is a shortcut for map[string]interface{}
type H map[string]interface{}
所以,咱们能够间接应用gin.H{}来代替:
package main
import (
"github.com/gin-gonic/gin"
"net/http"
)
func main() {
r := gin.Default()
r.GET("/json", func(c *gin.Context) {
//这里结构服务器要返回前端的数据,一共有两种办法,第一种是:应用map将数据序列化
//,这个map的key是一个string, value是一个空的接口(这样即能够实现接管任意类型的数据)
//data := map[string]interface{}{
// "name": "liber",
// "message": "hey liber~",
// "age": 16,
//}
data := gin.H{
"name": "libro",
"message": "hey libro~",
"age": 17,
}
//这里要返回json格局的数据,所以用c.JSON,这样,数据就返回给申请方了
c.JSON(http.StatusOK, data)
})
r.Run(":9090")
}
测试后果如下:
基于构造体的JSON数据生成
其实就是另一种写法而已:
package main
import (
"github.com/gin-gonic/gin"
"net/http"
)
func main() {
r := gin.Default()
r.GET("/json", func(c *gin.Context) {
//这里结构服务器要返回前端的数据,一共有两种办法,第一种是:应用map将数据序列化
//,这个map的key是一个string, value是一个空的接口(这样即能够实现接管任意类型的数据)
//data := map[string]interface{}{
// "name": "liber",
// "message": "hey liber~",
// "age": 16,
//}
data := gin.H{
"name": "libro",
"message": "hey libro~",
"age": 17,
}
//这里要返回json格局的数据,所以用c.JSON,这样,数据就返回给申请方了
c.JSON(http.StatusOK, data)
})
//这里介绍生成JSON数据的第二种办法:利用构造体
//首先结构一个构造体
type msg struct {
Name string
Message string
Age int
}
//而后构建一个构造体的实例
r.GET("/another_json", func(c *gin.Context) {
data := msg{
Name: "libro",
Message: "hey libro~",
Age: 17,
}
c.JSON(http.StatusOK, data)
})
r.Run(":9090")
}
测试后果如图:
不过须要留神的是,如果应用构造体,字段结尾字母必须大写,否则就没方法实现JSON的序列化,因为JSON序列化过程中应用到了Go内置的反射机制,小写示意不可导出。当然这也有解决之道,就是打tag:
//这里假如 前端就须要小写的name
type msg struct {
Name string `json: "name"`
Message string
Age int
}
其实我感觉,既然有坑,间接规定用第一种办法躲避掉是一种简洁&理智的抉择。
参考: bilibili
发表回复