项目地址
https://github.com/hetiansu5/urlquery
简介
使用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,所以编码后其实是整型,解码的时候也需要接收的是整型