经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Go语言 » 查看文章
Go语言实现Base64、Base58编码与解码
来源:jb51  时间:2021/7/26 14:07:16  对本文有异议

1. 常见的编码

base64:26个小写字母、26个大写字母、10个数字、/、+
base58(区块链):去掉6个容易混淆的,去掉0,大写的O、大写的I、小写的L、/、+/、+影响双击选择

2. go语言实现base64的编码与解码

2.1 Base64编码原理

Base64是一种编码方式,而并非加密,这种编码因为采用的64种基础字符(可见字符)所以可以全世界通用,大家都认可这一套编码规范

2.2 实现Base64的编码与解码

base64

  1. package main
  2.  
  3. import (
  4. "encoding/base64"
  5. "fmt"
  6. )
  7.  
  8. func Base64Encoding(str string) string { //Base64编码
  9. src := []byte(str)
  10. res := base64.StdEncoding.EncodeToString(src) //将编码变成字符串
  11. return res
  12. }
  13.  
  14. func Base64Decoding(str string) string { //Base64解码
  15. res,_:=base64.StdEncoding.DecodeString(str)
  16. return string(res)
  17. }
  18.  
  19. func main() {
  20. src := "FanOne"
  21. res := Base64Encoding(src) // 编码
  22. fmt.Println("FanOne 编码成为:",res)
  23. ret := Base64Decoding(res) //解码
  24. fmt.Println(res,"解码成为:",ret)
  25. }
  26. /*
  27. 结果:
  28. FanOne 编码成为: RmFuT25l
  29. RmFuT25l 解码称为: FanOne
  30. */

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编解码具体实现

  1. package main
  2.  
  3. import (
  4. "bytes"
  5. "fmt"
  6. "math/big"
  7. )
  8.  
  9.  
  10. var base58= []byte("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz")
  11.  
  12. func Base58Encoding(str string) string { //Base58编码
  13. //1. 转换成ascii码对应的值
  14. strByte := []byte(str)
  15. //fmt.Println(strByte) // 结果[70 97 110]
  16. //2. 转换十进制
  17. strTen := big.NewInt(0).SetBytes(strByte)
  18. //fmt.Println(strTen) // 结果4612462
  19. //3. 取出余数
  20. var modSlice []byte
  21. for strTen.Cmp(big.NewInt(0)) > 0 {
  22. mod:=big.NewInt(0) //余数
  23. strTen58:=big.NewInt(58)
  24. strTen.DivMod(strTen,strTen58,mod) //取余运算
  25. modSlice = append(modSlice, base58[mod.Int64()]) //存储余数,并将对应值放入其中
  26. }
  27. // 处理0就是1的情况 0使用字节'1'代替
  28. for _,elem := range strByte{
  29. if elem!=0{
  30. break
  31. }else if elem == 0{
  32. modSlice = append(modSlice,byte('1'))
  33. }
  34. }
  35. //fmt.Println(modSlice) //结果 [12 7 37 23] 但是要进行反转,因为求余的时候是相反的。
  36. //fmt.Println(string(modSlice)) //结果D8eQ
  37. ReverseModSlice:=ReverseByteArr(modSlice)
  38. //fmt.Println(ReverseModSlice) //反转[81 101 56 68]
  39. //fmt.Println(string(ReverseModSlice)) //结果Qe8D
  40. return string(ReverseModSlice)
  41. }
  42.  
  43. func ReverseByteArr(bytes []byte) []byte{ //将字节的数组反转
  44. for i:=0; i<len(bytes)/2 ;i++{
  45. bytes[i],bytes[len(bytes)-1-i] = bytes[len(bytes)-1-i],bytes[i] //前后交换
  46. }
  47. return bytes
  48. }
  49.  
  50. //就是编码的逆过程
  51. func Base58Decoding(str string) string { //Base58解码
  52. strByte := []byte(str)
  53. //fmt.Println(strByte) //[81 101 56 68]
  54. ret := big.NewInt(0)
  55. for _,byteElem := range strByte{
  56. index := bytes.IndexByte(base58,byteElem) //获取base58对应数组的下标
  57. ret.Mul(ret,big.NewInt(58)) //相乘回去
  58. ret.Add(ret,big.NewInt(int64(index))) //相加
  59. }
  60. //fmt.Println(ret) // 拿到了十进制 4612462
  61. //fmt.Println(ret.Bytes()) //[70 97 110]
  62. //fmt.Println(string(ret.Bytes()))
  63. return string(ret.Bytes())
  64. }
  65.  
  66. func main() {
  67. src := "Fan"
  68. res := Base58Encoding(src)
  69. fmt.Println(res) //Qe8D
  70. resD:=Base58Decoding(res)
  71. fmt.Println(resD) //Fan
  72. }

4. 最后

到此这篇关于Go语言实现Base64、Base58编码与解码的文章就介绍到这了,更多相关Go语言Base64、Base58编码与解码内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号