Golang Base64編碼解碼
Golang內置支持Base64編碼解碼,Go的encoding/base64
包遵照RFC 4648規範實現了base64編碼解碼功能,包括標準方式以及URL/文件名稱安全方式編碼。本文通過示例演示如何編碼和解碼。
1. Base64 標準方式編碼解碼
RFC 4648規範約定標準Base64對任何二進制數據使用US-ASCII字符子集進行編碼,字符包括:A-Z, a-z, 0-9, +, and /
。
編碼示例:
func encode() {
data := "hello world12345!?$*&()'-@~"
// Base64 Standard Encoding
sEnc := base64.StdEncoding.EncodeToString([]byte(data))
fmt.Println(sEnc) // aGVsbG8gd29ybGQxMjM0NSE/JComKCknLUB+
}
解碼示例:
func decode() {
data := "hello world12345!?$*&()'-@~"
sEnc := base64.StdEncoding.EncodeToString([]byte(data))
// Base64 Standard Decoding
sDec, err := base64.StdEncoding.DecodeString(sEnc)
if err != nil {
fmt.Printf("Error decoding string: %s ", err.Error())
return
}
fmt.Println(string(sDec)) //hello world12345!?$*&()'-@~
}
2. URL和文件名安全編碼解碼
URL和文件名安全方式是標準方式的變體,其輸出用於URL和文件名。因爲+
和/
字符是標準Base64字符對URL和文件名編碼不安全,變體即使用-
代替+
,_
(下劃線)代替/
。
編碼示例:
func encode() {
data := "hello world12345!?$*&()'-@~"
// Base64 Url Encoding
uEnc := base64.URLEncoding.EncodeToString([]byte(data))
fmt.Println(uEnc) // aGVsbG8gd29ybGQxMjM0NSE_JComKCknLUB-
}
解碼示例:
func decode() {
data := "hello world12345!?$*&()'-@~"
uEnc := base64.URLEncoding.EncodeToString([]byte(data))
// Base64 Url Decoding
uDec, err := base64.URLEncoding.DecodeString(uEnc)
if err != nil {
fmt.Printf("Error decoding string: %s ", err.Error())
return
}
fmt.Println(string(uDec)) // "hello world12345!?$*&()'-@~"
}
3. 無填充編碼
標準Base64編碼對輸出結果使用=
進行填充。一般也建議使用填充方式,但一些場景無需填充。我們可以使用Raw方式編碼即沒有填充。
無填充編碼示例:
func main() {
data := "abc!?$*&()'-@~"
// Base64 Encoding without Padding
swEnc := base64.RawStdEncoding.EncodeToString([]byte(data))
fmt.Println(swEnc) // YWJjIT8kKiYoKSctQH4
// Base64 Url Encoding without Padding
uwEnc := base64.RawURLEncoding.EncodeToString([]byte(data))
fmt.Println(uwEnc) //YWJjIT8kKiYoKSctQH4
}
4. 總結
本文介紹了Golang內置支持Base64編碼解碼,確實很簡單、很方便。