Go语言中encoding/base64包提供Base64编解码功能,1. 使用base64.StdEncoding.EncodeToString将字节切片编码为标准Base64字符串;2. 通过base64.StdEncoding.DecodeString将Base64字符串还原并检查错误;3. Web场景中使用base64.URLEncoding避免+和/在URL中的问题,适用于JWT等协议。

在Go语言中,encoding/base64 包提供了标准的Base64编码和解码功能,适用于处理二进制数据与文本格式之间的转换。常见于HTTP传输、JSON中嵌入图片、Token生成等场景。下面介绍如何使用该包进行实际的数据处理。
Base64 编码基本用法
要将原始字节数据编码为Base64字符串,可使用 base64.StdEncoding.EncodeToString 方法:
- 输入是字节切片([]byte),输出是标准Base64编码后的字符串
- 适合处理普通数据,如文本、图片内容等
package main
import (
"encoding/base64"
"fmt"
)
func main() {
data := []byte("Hello, 世界!")
encoded := base64.StdEncoding.EncodeToString(data)
fmt.Println("编码结果:", encoded) // 输出: SGVsbG8sIOS4lueVjCE=
}
Base64 解码操作
从Base64字符串还原原始数据,使用 base64.StdEncoding.DecodeString:
- 返回解码后的字节切片和错误信息
- 需检查错误,防止传入非法字符导致解析失败
decoded, err := base64.StdEncoding.DecodeString(encoded)
if err != nil {
fmt.Println("解码失败:", err)
return
}
fmt.Println("解码结果:", string(decoded)) // Hello, 世界!
处理 URL 安全的 Base64
在Web应用中,标准Base64中的 + 和 / 可能在URL中引起问题。此时应使用 base64.URLEncoding:
立即学习“go语言免费学习笔记(深入)”;
- 替换 + 为 -,/ 为 _,更适合放在查询参数或Token中
- JWT、OAuth等协议常用此编码方式
urlEncoded := base64.URLEncoding.EncodeToString([]byte("token-data"))
fmt.Println("URL安全编码:", urlEncoded)
back, _ := base64.URLEncoding.DecodeString(urlEncoded)
fmt.Println("还原数据:", string(back))
基本上就这些。encoding/base64 使用简单,关键是根据场景选择 StdEncoding 还是 URLEncoding,并注意处理解码时可能发生的错误。实际项目中建议封装成工具函数复用。










