亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Go語(yǔ)言實(shí)現(xiàn)Base64、Base58編碼與解碼

 更新時(shí)間:2021年07月26日 11:55:31   作者:小生凡一  
本文主要介紹了Base64、Base58編碼與解碼,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

1. 常見(jiàn)的編碼

base64:26個(gè)小寫(xiě)字母、26個(gè)大寫(xiě)字母、10個(gè)數(shù)字、/、+
base58(區(qū)塊鏈):去掉6個(gè)容易混淆的,去掉0,大寫(xiě)的O、大寫(xiě)的I、小寫(xiě)的L、/、+/、+影響雙擊選擇

2. go語(yǔ)言實(shí)現(xiàn)base64的編碼與解碼

2.1 Base64編碼原理

Base64是一種編碼方式,而并非加密,這種編碼因?yàn)椴捎玫?4種基礎(chǔ)字符(可見(jiàn)字符)所以可以全世界通用,大家都認(rèn)可這一套編碼規(guī)范

2.2 實(shí)現(xiàn)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)
}
/*
結(jié)果:
FanOne 編碼成為: RmFuT25l
RmFuT25l 解碼稱為: FanOne
*/

3. go語(yǔ)言實(shí)現(xiàn)base58編碼與解碼

Base58編碼表

3.1 base58的編碼過(guò)程

  • 將字符串的每個(gè)字節(jié)換算成ASCII,字符串實(shí)際上就是256進(jìn)制的數(shù)字組合
  • 將256進(jìn)制的數(shù)字轉(zhuǎn)換成10進(jìn)制數(shù)字
  • 將10進(jìn)制數(shù)字轉(zhuǎn)換成58進(jìn)制數(shù)字(除以58,每次得到的余數(shù)就是對(duì)應(yīng)的58進(jìn)制,0用編碼1來(lái)代表)
  • 將58進(jìn)制數(shù)字對(duì)照58編碼表找到對(duì)應(yīng)的字符

例子:

  • Fan對(duì)應(yīng)的換成ASCII:77 97 110
  • 將77 97 110的256轉(zhuǎn)換10進(jìn)值:77256256 + 97*256 + 110 = 4612462
  • 將4612462除以58,每次得到的余數(shù)就是對(duì)應(yīng)的58進(jìn)制,0用編碼1來(lái)代表:
  • 用余數(shù)的值去查表

3.2 base58編解碼具體實(shí)現(xiàn)

package main

import (
 "bytes"
 "fmt"
 "math/big"
)


var base58= []byte("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz")

func Base58Encoding(str string) string {   //Base58編碼
 //1. 轉(zhuǎn)換成ascii碼對(duì)應(yīng)的值
 strByte := []byte(str)
 //fmt.Println(strByte) // 結(jié)果[70 97 110]
 //2. 轉(zhuǎn)換十進(jìn)制
 strTen := big.NewInt(0).SetBytes(strByte)
 //fmt.Println(strTen)  // 結(jié)果4612462
 //3. 取出余數(shù)
 var modSlice []byte
 for strTen.Cmp(big.NewInt(0)) > 0 {
  mod:=big.NewInt(0)     //余數(shù)
  strTen58:=big.NewInt(58)
  strTen.DivMod(strTen,strTen58,mod)  //取余運(yùn)算
  modSlice = append(modSlice, base58[mod.Int64()])    //存儲(chǔ)余數(shù),并將對(duì)應(yīng)值放入其中
  }
 //  處理0就是1的情況 0使用字節(jié)'1'代替
 for _,elem := range strByte{
  if elem!=0{
   break
  }else if elem == 0{
   modSlice = append(modSlice,byte('1'))
  }
 }
 //fmt.Println(modSlice)   //結(jié)果 [12 7 37 23] 但是要進(jìn)行反轉(zhuǎn),因?yàn)榍笥嗟臅r(shí)候是相反的。
 //fmt.Println(string(modSlice))  //結(jié)果D8eQ
 ReverseModSlice:=ReverseByteArr(modSlice)
 //fmt.Println(ReverseModSlice)  //反轉(zhuǎn)[81 101 56 68]
 //fmt.Println(string(ReverseModSlice))  //結(jié)果Qe8D
 return string(ReverseModSlice)
}

func ReverseByteArr(bytes []byte) []byte{   //將字節(jié)的數(shù)組反轉(zhuǎn)
 for i:=0; i<len(bytes)/2 ;i++{
  bytes[i],bytes[len(bytes)-1-i] = bytes[len(bytes)-1-i],bytes[i]  //前后交換
 }
 return bytes
}

//就是編碼的逆過(guò)程
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對(duì)應(yīng)數(shù)組的下標(biāo)
  ret.Mul(ret,big.NewInt(58))     //相乘回去
  ret.Add(ret,big.NewInt(int64(index)))  //相加
 }
 //fmt.Println(ret)  // 拿到了十進(jìn)制 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. 最后

到此這篇關(guān)于Go語(yǔ)言實(shí)現(xiàn)Base64、Base58編碼與解碼的文章就介紹到這了,更多相關(guān)Go語(yǔ)言Base64、Base58編碼與解碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Golang?中實(shí)現(xiàn)?Set的思路詳解

    Golang?中實(shí)現(xiàn)?Set的思路詳解

    本文介紹了Go中兩種set的實(shí)現(xiàn)原理,并在此基礎(chǔ)介紹了對(duì)應(yīng)于它們的兩個(gè)包簡(jiǎn)單使用,本文介紹的非常詳細(xì),需要的朋友參考下吧
    2024-01-01
  • golang雙指針快速排序的實(shí)現(xiàn)代碼

    golang雙指針快速排序的實(shí)現(xiàn)代碼

    這篇文章主要介紹了golang雙指針快速排序的實(shí)現(xiàn)代碼,通過(guò)實(shí)例代碼補(bǔ)充介紹了Golang實(shí)現(xiàn)快速排序和歸并排序以及堆排序算法全注釋,需要的朋友可以參考下
    2024-03-03
  • Go語(yǔ)言中常見(jiàn)的文件操作分享

    Go語(yǔ)言中常見(jiàn)的文件操作分享

    文件操作應(yīng)該是應(yīng)用程序里非常常見(jiàn)的一種操作,無(wú)論是哪種應(yīng)用場(chǎng)景,幾乎都離不開(kāi)文件的基本操作。Go語(yǔ)言中提供了三個(gè)不同的包去處理文件,下午就來(lái)說(shuō)說(shuō)它們的具體使用
    2023-01-01
  • 使用Go語(yǔ)言與MQTT進(jìn)行通信的示例代碼

    使用Go語(yǔ)言與MQTT進(jìn)行通信的示例代碼

    本文介紹了如何使用 Go 編程語(yǔ)言與 MQTT(Message Queuing Telemetry Transport)進(jìn)行通信,MQTT 是一種輕量級(jí)的消息傳輸協(xié)議,廣泛應(yīng)用于物聯(lián)網(wǎng)和實(shí)時(shí)通信場(chǎng)景,通過(guò)本文的指導(dǎo),您將學(xué)習(xí)如何使用 Go 語(yǔ)言創(chuàng)建 MQTT 客戶端,進(jìn)行消息的發(fā)布和訂閱,需要的朋友可以參考下
    2023-12-12
  • Golang分布式鎖簡(jiǎn)單案例實(shí)現(xiàn)流程

    Golang分布式鎖簡(jiǎn)單案例實(shí)現(xiàn)流程

    分布式鎖是控制分布式系統(tǒng)之間同步訪問(wèn)共享資源的一種方式。如果不同的系統(tǒng)或是同一個(gè)系統(tǒng)的不同主機(jī)之間共享了一個(gè)或一組資源,那么訪問(wèn)這些資源時(shí),需要通過(guò)一些互斥手段來(lái)防止彼此之間的干擾以保證一致性,在這種情況下,就需要使用分布式鎖了
    2022-12-12
  • 詳解Golang中零拷貝的原理以及實(shí)踐

    詳解Golang中零拷貝的原理以及實(shí)踐

    零拷貝技術(shù)相信大家都有所耳聞,但是本文不僅會(huì)講述零拷貝技術(shù)的原理,并將從實(shí)際代碼出發(fā),看看零拷貝技術(shù)在golang中的應(yīng)用,現(xiàn)在讓我們開(kāi)始吧
    2023-07-07
  • go語(yǔ)言定義零值可用的類型學(xué)習(xí)教程

    go語(yǔ)言定義零值可用的類型學(xué)習(xí)教程

    這篇文章主要為大家介紹了go語(yǔ)言定義零值可用的類型教程學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • MacOS下本地golang環(huán)境搭建詳細(xì)教程

    MacOS下本地golang環(huán)境搭建詳細(xì)教程

    這篇文章主要介紹了MacOS下本地golang環(huán)境搭建詳細(xì)教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • Golang中的godoc使用簡(jiǎn)介(推薦)

    Golang中的godoc使用簡(jiǎn)介(推薦)

    Godoc是go語(yǔ)言的文檔化工具,類似于文檔化工具godoc,類似于Python的Docstring和Java的Javadoc,這篇文章主要介紹了Golang中的godoc使用簡(jiǎn)介,需要的朋友可以參考下
    2022-10-10
  • Golang學(xué)習(xí)筆記(四):array、slice、map

    Golang學(xué)習(xí)筆記(四):array、slice、map

    這篇文章主要介紹了Golang學(xué)習(xí)筆記(四):array、slice、map,本文分別講解了這3個(gè)類型的聲明&賦值、元素訪問(wèn)、其它操作,需要的朋友可以參考下
    2015-05-05

最新評(píng)論