Golang对未知结构json的解析

  Golang的json包解析可以让你在程序中方便的读取和写入JSON 数据。

  • 生成JSON场景相对简单一些,json.Marshal()会根据传入的结构体生成JSON数据。
  • 解析JSON会把数据解析到结构体中,由于JSON格式的可能根据其传递参数的值,来判断类型,这种自由组合的特点,就需要采用泛型的接口类型解决。本文重点描述对未知结构体数据的解析,主要分为如下1和2两个步骤,示例对未知结构体Params进行解析,Params的结构体类型通过Object传递过来参数确定。

1. 将未知结构体解析为interface{}类型

//请求消息类型,客户端收到该类型json并进行解析。用interface{}代表任意结构类型
type MsgRequest struct {
	TimeStamp uint64      `json:"timestamp"`
	Object    string      `json:"object"`
	Params    interface{} `json:"params"`
}

//这里先解析接收到的数据类型,params为未知的json类型
var Msg MsgRequest
if err = json.Unmarshal(msg.Payload(), &Msg); err != nil {
	log.Error(err)
}

2. 转化interface{}类型为指定结构体

  读者可以采用如下两种方式中的任意一个完成转化,希望转为的数据类型,在接收到的消息Msg.Object中已定义。

  • 通过序列化和反序列化完成转化

  这里先重新序列化未知结构体Params为[]byte结构类型数据ByteParams, 然后再根据消息内容转化为对应结构体类型数据。

//OBJ_Test1
type Test1_OBJ struct {
	Id 		uint64      `json:"id"`
	Name    string      `json:"string"`
}

ByteParams, _ := json.Marshal(Msg.Params)
switch {
	case Msg.Object == OBJ_Test1:
		var test1 Test1_OBJ
		if err = json.Unmarshal(ByteParams, &test1); err != nil {
			log.Error(err)
		}else {
			//todo
		}
	case Msg.Object == OBJ_Test2:
			...
	default:
	}
}
  • 通过interface{}结构类型转化

  这里根据消息内容,直接将interface{}转化为对应结构体类型数据。

//OBJ_Test1
type Test1_OBJ struct {
	Id 		uint64      `json:"id"`
	Name    string      `json:"string"`
}

switch {
	case Msg.Object == OBJ_Test1:
		var test1 Test1_OBJ
		if test1,ok := (Msg.Params).(Test1_OBJ); ok {
			//todo
		}else {
			log.Error(err)
		}
	case Msg.Object == OBJ_Test2:
		...
	default:
	}
}

本文源站链接:https://turbock79.cn/?p=1905

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Golang中,map转换为JSON格式时,默认情况下是无序的。这是因为Golang的map是无序的数据结构,而JSON本身也是一个无序的键值对集合。所以,JSON的参数顺序在大多数情况下对使用没有影响。如果你希望生成有序的JSON数据,可以使用第三方库,例如`encoding/json`包中的`MarshalIndent`函数,通过设置`indent`参数来实现按照一定格式生成有序的JSON数据。你可以在代码中指定需要的键值对顺序,然后将map转换为JSON数据。这样,生成的JSON数据将会按照你指定的顺序进行排列。 示例代码如下: ```go import ( "encoding/json" "fmt" "sort" ) func main() { m := map[string]interface{}{ "key1": "value1", "key3": "value3", "key2": "value2", } keys := make([]string, 0, len(m)) for k := range m { keys = append(keys, k) } sort.Strings(keys) orderedMap := make(map[string]interface{}) for _, k := range keys { orderedMap[k = m[k] } jsonData, err := json.MarshalIndent(orderedMap, "", " ") if err != nil { fmt.Println("Error:", err) return } fmt.Println(string(jsonData)) } ``` 以上示例代码中,我们先将map的键取出并排序,然后根据排序后的键重新构建一个有序的map。最后使用`json.MarshalIndent`函数将有序的map转换为有序的JSON数据,并打印输出。这样就能生成按照键的顺序排列的JSON数据了。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [Golang map如何生成有序的json数据详解](https://download.csdn.net/download/weixin_38713039/12872560)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [golang map转json的顺序问题](https://blog.csdn.net/xz_studying/article/details/103219478)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值