如何在Golang中使用encoding/base64进行编码解码_Golang encoding/base64编码解码方法汇总

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

如何在Golang中使用encoding/base64进行编码解码_Golang encoding/base64编码解码方法汇总

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安全编码,它用 _ 替代 +/

编码与解码示例:

如何在Golang中使用encoding/base64进行编码解码_Golang encoding/base64编码解码方法汇总

文心快码

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

如何在Golang中使用encoding/base64进行编码解码_Golang encoding/base64编码解码方法汇总35

查看详情 如何在Golang中使用encoding/base64进行编码解码_Golang encoding/base64编码解码方法汇总

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)) 

基本上就这些。掌握 StdEncodingURLEncodingRawStdEncoding 这几种方式,就能应对大多数Base64使用场景。注意编码与解码必须使用相同的格式,否则会出错。

上一篇
下一篇
text=ZqhQzanResources