Go之URL Query String编码器和解码器

1,461 阅读2分钟

项目地址

github.com/hetiansu5/u…

简介

使用Go语言实现的URL Query字符串编码器和解码器。写好后才发现官方已有实现的querystring,但只实现了编码器,没有解码器,且只支持顶层数据结构为结构体,实现上不算特别完善。

特性

  • 支持丰富的Go数据结构互转:
    • 基础数据类型: 有符号整型[8,16,32,64] 无符号整形[8,16,32,64] 字符串 布尔值 浮点型[32,64] 字节 字面量
    • 复合数据类型: 数组 切片 哈希 结构体
    • 嵌套结构体
  • 支持顶层的数据结构为数组 切片 哈希,不仅仅是结构体
  • 支持自定义的URL-Encode编码规则,支持全局、局部设置方式,支持默认规则
  • 支持自定义的键名映射规则(结构体Tag示例:query:"name"
  • 支持开启或者关闭忽略结构体零值编码(默认开启),以减少编码后字符串长度

快速入门

更多查看example

package main

import (
	"github.com/hetiansu5/urlquery"
	"fmt"
)

type SimpleChild struct {
	Status bool `query:"status"`
	Name   string
}

type SimpleData struct {
	Id         int
	Name       string          `query:"name"`
	Child      SimpleChild
	Params     map[string]int8 `query:"p"`
	Array      [3]uint16
}

func main() {
	data := SimpleData{
		Id:   2,
		Name: "http://localhost/test.php?id=2",
		Child: SimpleChild{
			Status: true,
		},
		Params: map[string]int8{
			"one": 1,
		},
		Array: [3]uint16{2, 3, 300},
	}

	//Marshal: from go structure to url query string
	bytes, _ := urlquery.Marshal(data)
	fmt.Println(string(bytes))

	//Unmarshal: from url query  string to go structure
	v := &SimpleData{}
	urlquery.Unmarshal(bytes, v)
	fmt.Println(*v)

注意事项

  • 针对Map数据类型,Marshal可以支持map[基础数据类型]基础数据类型|复合数据类型,Unmarshal只能支持map[基础数据类型]基础数据类型
  • 结构体零值忽略编码默认开启,可以通过Option关闭此功能
  • 字节实际上是uint8,字面量是int32,所以编码后其实是整型,解码的时候也需要接收的是整型