Go語言實現Base64、Base58編碼與解碼
1. 常見的編碼
base64:26個小寫字母、26個大寫字母、10個數字、/、+
base58(區塊鏈):去掉6個容易混淆的,去掉0,大寫的O、大寫的I、小寫的L、/、+/、+影響雙擊選擇
2. go語言實現base64的編碼與解碼
2.1 Base64編碼原理
Base64是一種編碼方式,而並非加密,這種編碼因為采用的64種基礎字符(可見字符)所以可以全世界通用,大傢都認可這一套編碼規范
2.2 實現Base64的編碼與解碼
base64
package main import ( "encoding/base64" "fmt" ) func Base64Encoding(str string) string { //Base64編碼 src := []byte(str) res := base64.StdEncoding.EncodeToString(src) //將編碼變成字符串 return res } func Base64Decoding(str string) string { //Base64解碼 res,_:=base64.StdEncoding.DecodeString(str) return string(res) } func main() { src := "FanOne" res := Base64Encoding(src) // 編碼 fmt.Println("FanOne 編碼成為:",res) ret := Base64Decoding(res) //解碼 fmt.Println(res,"解碼成為:",ret) } /* 結果: FanOne 編碼成為: RmFuT25l RmFuT25l 解碼稱為: FanOne */
3. go語言實現base58編碼與解碼
Base58編碼表
3.1 base58的編碼過程
- 將字符串的每個字節換算成ASCII,字符串實際上就是256進制的數字組合
- 將256進制的數字轉換成10進制數字
- 將10進制數字轉換成58進制數字(除以58,每次得到的餘數就是對應的58進制,0用編碼1來代表)
- 將58進制數字對照58編碼表找到對應的字符
例子:
- Fan對應的換成ASCII:77 97 110
- 將77 97 110的256轉換10進值:77256256 + 97*256 + 110 = 4612462
- 將4612462除以58,每次得到的餘數就是對應的58進制,0用編碼1來代表:
- 用餘數的值去查表
3.2 base58編解碼具體實現
package main import ( "bytes" "fmt" "math/big" ) var base58= []byte("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz") func Base58Encoding(str string) string { //Base58編碼 //1. 轉換成ascii碼對應的值 strByte := []byte(str) //fmt.Println(strByte) // 結果[70 97 110] //2. 轉換十進制 strTen := big.NewInt(0).SetBytes(strByte) //fmt.Println(strTen) // 結果4612462 //3. 取出餘數 var modSlice []byte for strTen.Cmp(big.NewInt(0)) > 0 { mod:=big.NewInt(0) //餘數 strTen58:=big.NewInt(58) strTen.DivMod(strTen,strTen58,mod) //取餘運算 modSlice = append(modSlice, base58[mod.Int64()]) //存儲餘數,並將對應值放入其中 } // 處理0就是1的情況 0使用字節'1'代替 for _,elem := range strByte{ if elem!=0{ break }else if elem == 0{ modSlice = append(modSlice,byte('1')) } } //fmt.Println(modSlice) //結果 [12 7 37 23] 但是要進行反轉,因為求餘的時候是相反的。 //fmt.Println(string(modSlice)) //結果D8eQ ReverseModSlice:=ReverseByteArr(modSlice) //fmt.Println(ReverseModSlice) //反轉[81 101 56 68] //fmt.Println(string(ReverseModSlice)) //結果Qe8D return string(ReverseModSlice) } func ReverseByteArr(bytes []byte) []byte{ //將字節的數組反轉 for i:=0; i<len(bytes)/2 ;i++{ bytes[i],bytes[len(bytes)-1-i] = bytes[len(bytes)-1-i],bytes[i] //前後交換 } return bytes } //就是編碼的逆過程 func Base58Decoding(str string) string { //Base58解碼 strByte := []byte(str) //fmt.Println(strByte) //[81 101 56 68] ret := big.NewInt(0) for _,byteElem := range strByte{ index := bytes.IndexByte(base58,byteElem) //獲取base58對應數組的下標 ret.Mul(ret,big.NewInt(58)) //相乘回去 ret.Add(ret,big.NewInt(int64(index))) //相加 } //fmt.Println(ret) // 拿到瞭十進制 4612462 //fmt.Println(ret.Bytes()) //[70 97 110] //fmt.Println(string(ret.Bytes())) return string(ret.Bytes()) } func main() { src := "Fan" res := Base58Encoding(src) fmt.Println(res) //Qe8D resD:=Base58Decoding(res) fmt.Println(resD) //Fan }
4. 最後
到此這篇關於Go語言實現Base64、Base58編碼與解碼的文章就介紹到這瞭,更多相關Go語言Base64、Base58編碼與解碼內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Golang語言學習拿捏Go反射示例教程
- go語言實戰之實現比特幣地址校驗步驟
- python數據類型bytes 和 bytearray的使用與區別
- go 迭代string數組操作 go for string[]
- go語言中的json與map相互轉換實現