go 标准库 `net/url` 提供了安全、规范的 url 编码能力,可对查询参数或完整 url 进行百分号编码(url encoding),避免因空格、单引号、括号等非法字符导致请求失败。
在 Go 中处理含空格或特殊字符(如 '、(、)、+、:、/ 等)的 URL 时,绝不能手动替换或拼接字符串,而应使用标准库 net/url 提供的专用函数,确保符合 RFC 3986 规范。
当 URL 的路径部分固定、仅查询参数(如 script=...)含动态内容时,应只对参数值进行编码:
package main
import (
"fmt"
"net/url"
)
func main() {
script := `g.addVertex(['id':'0af69422 5be','date':'1968-01-16 00:00:00 +0000 UTC'])`
encoded := url.QueryEscape(script)
fmt.Println(encoded)
// 输出:g.addVertex%28[%27id%27%3A%270af69422+5be%27%2C%27date%27%3A%271968-01-16+00%3A00%3A00+%2B0000+UTC%27]%29
fullURL := "http://localhost:8182/graphs/graph/tp/gremlin?script=" + encoded
fmt.Println(fullURL)
}? url.QueryEscape() 专为编码 URL 查询参数值 设计:它将空格转为 +(符合 application/x-www-form-urlencoded 规范),并正确编码保留字符(如 ' → %27,( → %28)。
若 URL 包含多个查询参数(如 ?script=...&lang=gremlin&bindings=),推荐使用 url.URL 和 url.Values 结构化构建:
u, _ := url.Parse("http://localhost:8182/graphs/graph/tp/gremlin")
q := u.Query()
q.Set("script", `g.addVertex(['id':'0af69422 5be','date':'1968-01-16 00:00:00 +0000 UTC'])`)
q.Set("lang", "gremlin")
u.RawQuery = q.Encode()
fmt.Println(u.String())
// 输出:http://localhost:8182/graphs/graph/tp/gremlin?lang=gremlin&script=g.addVertex%28[%27id%27%3A%270af69422+5be%27%2C%27date%27%3A%271968-01-16+00%3A00%3A00+%2B0000+UTC%27]%29此方式自动处理键值对编码、排序与分隔,彻底规避手工拼接风险。

总之,Go 的 net/url 是 URL 构建与编码的权威方案——坚持「结构化解析 → 参数化设置 → 安全编码」三步法,即可稳健应对任意复杂 URL 场景。