GO 全面解析 json tag 篇

在处理json格式字符串的时候,经常会看到声明struct结构的时候,属性的右侧还有反引号括起来的内容。形如:

1 type User struct {
2     UserId   int    `json:"user_id" bson:"user_id"`
3     UserName string `json:"user_name" bson:"user_name"`
4 }

struct成员变量标签(Tag)说明

要比较详细的了解这个,要先了解一下golang的基础,在golang中,命名都是推荐都是用驼峰方式,并且在首字母大小写有特殊的语法含义:包外无法引用。但是由经常需要和其它的系统进行数据交互,例如转成json格式,存储到mongodb啊等等。这个时候如果用属性名来作为键值可能不一定会符合项目要求。

所以呢就多了反引号的内容,在golang中叫标签(Tag),在转换成其它数据格式的时候,会使用其中特定的字段作为键值。例如上例在转成json格式:

1 u := &User{UserId: 1, UserName: "tony"}
2 j, _ := json.Marshal(u)
3 fmt.Println(string(j))

// 输出内容:

// {"user_id":1,"user_name":"tony"}

// 如果在属性中不增加标签说明,则输出:

// {"UserId":1,"UserName":"tony"}
// 可以看到直接用struct的属性名做键值。

// ==其中还有一个bson的声明,这个是用在将数据存储到mongodb使用的==

struct成员变量标签(Tag)获取

那么当我们需要自己封装一些操作,需要用到Tag中的内容时,咋样去获取呢?这边可以使用反射包(reflect)中的方法来获取:

1 t := reflect.TypeOf(u)
2 field := t.Elem().Field(0)
3 fmt.Println(field.Tag.Get("json"))
4 fmt.Println(field.Tag.Get("bson"))

完整代码如下:

 1 package main
 2  
 3 import (
 4     "encoding/json"
 5     "fmt"
 6     "reflect"
 7 )
 8  
 9 func main() {
10     type User struct {
11         UserId   int    `json:"user_id" bson:"user_id"`
12         UserName string `json:"user_name" bson:"user_name"`
13     }
14     // 输出json格式
15     u := &User{UserId: 1, UserName: "tony"}
16     j, _ := json.Marshal(u)
17     fmt.Println(string(j))
18     // 输出内容:{"user_id":1,"user_name":"tony"}
19  
20     // 获取tag中的内容
21     t := reflect.TypeOf(u)
22     field := t.Elem().Field(0)
23     fmt.Println(field.Tag.Get("json"))
24     // 输出:user_id
25     fmt.Println(field.Tag.Get("bson"))
26     // 输出:user_id
27 }

自定义tag

1 type User struct {
2     UserId   int    `json:"user_id" bson:"user_id" test:"test"`
3     UserName string `json:"user_name" bson:"user_name"`
4 }

获取tag中test的值

1 // 获取tag中的内容
2 typeof := reflect.TypeOf(u)
3 field := typeof.Elem().Field(0)
4 fmt.Println(field.Tag.Get("json"))
5 // 输出:user_id
6 fmt.Println(field.Tag.Get("bson"))
7 // 输出:user_id
8 fmt.Println(field.Tag.Get("test"))
9 // 输出:test

 

上一篇:GoLang 中用 MongoDB Watch 监听指定字段的变化


下一篇:mysql – 有没有人找到一种在SQL数据库中存储BSON ObjectId值的有效方法?