Golang encoding/base64数据编码与解码示例

Go语言中base64包提供Base64编解码功能,用于二进制与文本格式转换。1. 导入encoding/base64包;2. 使用StdEncoding.EncodeToString将字节切片编码为标准Base64字符串;3. 使用StdEncoding.DecodeString将Base64字符串解码并处理可能的错误;4. URL安全场景使用URLEncoding避免+和/字符;5. 可选RawStdEncoding去除填充符=以紧凑输出。常用场景包括网络传输、JWT等。

Golang encoding/base64数据编码与解码示例

在 Go 语言中,encoding/base64 包提供了标准的 Base64 编码和解码功能。Base64 常用于将二进制数据转换为文本格式,便于在网络传输或存储时避免乱码问题。

导入 base64 包

使用前需导入标准库

 import "encoding/base64" 

基本编码示例

将字符串或字节切片编码为 Base64 字符串:

 data := "Hello, 世界" encoded := base64.StdEncoding.EncodeToString([]byte(data)) // 输出: SGVsbG8sios4lueVjA== 

说明:先将字符串转为字节切片,再调用 EncodeToString 方法。

立即学习go语言免费学习笔记(深入)”;

基本解码示例

将 Base64 字符串还原为原始数据:

 encoded := "SGVsbG8sIOS4lueVjA==" decoded, err := base64.StdEncoding.DecodeString(encoded) if err != nil {     log.Fatal("解码失败:", err) } // 输出: Hello, 世界 fmt.Println(string(decoded)) 

注意:解码可能出错,比如输入不是合法的 Base64 字符串,需检查 error。

Golang encoding/base64数据编码与解码示例

文心快码

文心快码(Comate)是百度推出的一款AI辅助编程工具

Golang encoding/base64数据编码与解码示例35

查看详情 Golang encoding/base64数据编码与解码示例

处理 URL 安全的 Base64

如果 Base64 字符串用于 URL 或文件名,建议使用 URL 安全编码方式(将 + 和 / 替换为 – 和 _):

 // 编码 urlEncoded := base64.URLEncoding.EncodeToString([]byte("hello world")) <p>// 解码 decoded, err := base64.URLEncoding.DecodeString(urlEncoded)</p>

适用于 JWT、Token 等场景。

自定义编码配置(可选)

Go 还支持自定义字符集,例如不带填充符 ‘=’ 的编码:

 rawStd := base64.RawStdEncoding // 无填充的标准编码 encoded := rawStd.EncodeToString([]byte("test")) 

适合需要紧凑输出的场合。

基本上就这些。标准库使用简单,关键是选择合适的编码方式并处理好错误。实际开发中,StdEncoding 和 URLEncoding 最常用。

go golang go语言 编码 字节 ios 标准库 golang Error Token 字符串 Go语言 切片

上一篇
下一篇
text=ZqhQzanResources