go语言中encoding/base64包提供Base64编解码功能,1. 使用StdEncoding进行标准编解码,将字节转为含+和/的字符串;2. 用URLEncoding实现URL安全编解码,以-和_替代+和/;3. 处理带换行数据时需先去除空白字符再解码;4. 可用RawStdEncoding创建无填充符=的自定义编码,编解码需使用相同格式。

在Go语言中,encoding/base64 包提供了标准的Base64编码和解码功能。它常用于将二进制数据转换为文本格式,便于在网络传输或存储时避免乱码问题。下面介绍如何使用该包进行常见操作。
1. 使用标准Base64编码与解码
Go内置了两种常用的编码方式:标准编码(RFC 4648)和URL安全编码。标准Base64使用 + 和 / 字符。
编码示例:
package main import ( "encoding/base64" "fmt" ) func main() { data := []byte("hello golang") encoded := base64.StdEncoding.EncodeToString(data) fmt.Println("编码结果:", encoded) // 输出: aGVsbG8gZ29sYW5n }
解码示例:
立即学习“go语言免费学习笔记(深入)”;
decoded, err := base64.StdEncoding.DecodeString(encoded) if err != nil { fmt.Println("解码失败:", err) return } fmt.Println("解码结果:", string(decoded)) // 输出: hello golang
2. 使用URL安全的Base64编码
当Base64字符串需要放在URL或文件名中时,应使用URL安全编码,它用 – 和 _ 替代 + 和 /。
编码与解码示例:
data := []byte("user-id:123") // URL安全编码 encoded := base64.URLEncoding.EncodeToString(data) fmt.Println("URL编码:", encoded) // URL安全解码 decoded, err := base64.URLEncoding.DecodeString(encoded) if err != nil { fmt.Println("解码出错:", err) return } fmt.Println("解码后:", string(decoded))
3. 处理包含换行的Base64数据
某些Base64编码数据可能包含换行或空格(如PEM格式),直接解码会报错。可先去除空白字符再解码。
处理方法:
rawData := ` aGVsbG8gd29ybGQh ` cleanData := strings.TrimSpace(rawData) // 去除首尾空白 decoded, err := base64.StdEncoding.DecodeString(cleanData) if err != nil { fmt.Println("解码失败:", err) return } fmt.Println(string(decoded))
4. 自定义Base64编码表(可选)
Go允许创建自定义编码格式,比如不带填充符 ‘=’ 的Base64。
示例:无填充编码
noPadding := base64.RawStdEncoding // 不使用 '=' 填充 data := []byte("test") encoded := noPadding.EncodeToString(data) fmt.Println("无填充编码:", encoded) // 解码时也需使用相同的编码方式 decoded, err := noPadding.DecodeString(encoded) if err != nil { fmt.Println("解码失败:", err) return } fmt.Println("解码结果:", string(decoded))
基本上就这些。掌握 StdEncoding、URLEncoding 和 RawStdEncoding 这几种方式,就能应对大多数Base64使用场景。注意编码与解码必须使用相同的格式,否则会出错。


