Go反射通过reflect.StructField.Tag.Get("json")提取JSON标签,用strings.SplitN解析字段名,空标签按规范忽略,无标签则小写字段名;再遍历结构体构建map[string]reflect.StructField映射表。
Go 语言中,反射(reflect)本身不直接解析 JSON,但可以配合 encoding/json 包,动态获取结构体字段的 JSON 标签(tag),实现运行时字段匹配、校验、映射或自定义绑定逻辑。核心在于:用反射读取结构体字段的 json tag,再结合 JSON 数据的键名做对应处理。
Go 的结构体字段可通过 json:"name,omitempty" 这类 tag 声明序列化行为。反射能通过 reflect.StructField.Tag.Get("json") 提取该字符串,并进一步解析出字段名和选项。
strings.SplitN(tag, ",", 2)[0] 获取真实 JSON 字段名(去掉 omitempty 等修饰)json:""),按规范应忽略该字段;若未设 tag,默认使用字段名转小写(如 UserName → username)常见需求:将一个 map[string]interface{} 或原始 JSON 键名,映射到结构体字段上。可通过反射生成 map[string]reflect.StructField 表。
reflect.TypeOf(t).Elem() 获取指针指向的结构体类型(注意传入的是指针)for i := 0; i
jsonName := strings.SplitN(field.Tag.Get("json"), ",", 2)[0]
field.PkgPath != "" 表示非导出)jsonName == "-" ,显式忽略该字段适用于需要拦截、转换、日志或条件赋值的场景(例如:统一处理时间格式、字段重命名、权限过滤)。
json.RawMessage 或 map[string]json.RawMessage 解析原始 JSON,避免提前解码失败StructField 和其在结构体实例中的 reflect.Value
fieldVal.Set(...) 赋值前,做类型检查与转换(如 string → time.Time)sync.Map 存 reflect.Type → map[string]fieldInfo)基本上就这些。Golang 反射 + JSON 字段匹配不是为了替代 json.Unmarshal,而是为了在它之外获得控制权——比如中间件级参数预处理、低代码字段映射、兼容多版本 API 等场景。用得克制,效果清晰。