答案:Go的base64包支持标准和URL安全编码,用于二进制转文本,如JWT、图片传输;标准编码用base64.StdEncoding.EncodeToString,含+和/字符;URL安全编码用base64.URLEncoding避免特殊字符问题;解码需检查error,防止非法输入;可自定义编码但一般无需;注意字节切片转换与填充处理。

在Golang中,encoding/base64 包提供了标准的Base64编码和解码功能。它常用于将二进制数据转换为文本格式,便于在网络传输或配置中使用,比如处理图片、JWT、加密数据等场景。
导入 base64 包
使用前需要导入标准库中的 base64 包:
import "encoding/base64"
使用标准 Base64 编码
标准 Base64 使用字符集 A-Z、a-z、0-9、+ 和 /。可通过 base64.StdEncoding 进行编码:
data := []byte("hello world")
encoded := base64.StdEncoding.EncodeToString(data)
// 输出: aGVsbG8gd29ybGQ=
使用标准 Base64 解码
将 Base64 字符串还原为原始字节:
立即学习“go语言免费学习笔记(深入)”;
免费 盛世企业网站管理系统(SnSee)系统完全免费使用,无任何功能模块使用限制,在使用过程中如遇到相关问题可以去官方论坛参与讨论。开源 系统Web代码完全开源,在您使用过程中可以根据自已实际情况加以调整或修改,完全可以满足您的需求。强大且灵活 独创的多语言功能,可以直接在后台自由设定语言版本,其语言版本不限数量,可根据自已需要进行任意设置;系统各模块可在后台自由设置及开启;强大且适用的后台管理支
decoded, err := base64.StdEncoding.DecodeString("aGVsbG8gd29ybGQ=")
if err != nil {
log.Fatal("解码失败:", err)
}
// 输出: hello world
注意:解码可能出错,比如输入包含非法字符,因此必须检查返回的 error。
URL 安全的 Base64 编码(推荐用于 Web)
在 URL 或文件名中使用时,标准 Base64 的 + 和 / 可能引起问题。Go 提供了 URL 安全变体 base64.URLEncoding:
data := []byte("hello+world/")
encoded := base64.URLEncoding.EncodeToString(data)
// 输出: aGVsbG8rd29ybGQv
decoded, err := base64.URLEncoding.DecodeString(encoded)
自定义编码字符集(可选)
如果需要,可以用 base64.NewEncoding 创建自定义编码方式,例如修改填充字符或字符顺序,但大多数情况不需要。
常见注意事项
- 编码函数接受 []byte,字符串需先转为字节切片
- 解码函数返回字节切片,如需字符串可用 string(decoded)
- 标准编码使用 '=' 作为填充,若要省略填充,可用 WithPadding 配置
- URL 安全编码更适合 JWT、Token 等场景
基本上就这些。base64 在 Go 中简单可靠,只要注意选择合适的编码方式并处理错误即可。









