Base64 编码字符串

定义

Base64 是基于64个可打印字符来表示二进制数据的编解码方式,由于 Base64 仅可对 ASCII 字符进行编码,如果是中文字符等非ASCII码,就需要先将中文字符转换为ASCII字符后,再进行编码才行

主要的作用不在于安全性,而在于让内容能在各个网关间无错的传输

Base64是一种索引编码,每个字符都对应一个索引,64个可打印字符包括大写字母A-Z、小写字母a-z、数字0-9共62个字符,再加上另外2个 +/

由于64等于2的6次方,所以一个Base64字符实际上代表着6个二进制位(bit),二进制数据1个字节(byte)对应的是8比特(bit),因此,3字节(3 x 8 = 24比特)的字符串/二进制数据正好可以转换成4个Base64字符(4 x 6 = 24比特)

具体的编码方式:

  • 将每3个字节作为一组,3个字节一共24个二进制位

  • 将这24个二进制位分为4组,每个组有6个二进制位

  • 在每组的6个二进制位前面补两个00,扩展成32个二进制位,即四个字节

  • 每个字节对应的将是一个小于64的数字,即为字符编号

  • 再根据字符索引关系表,每个字符编号对应一个字符,就得到了Base64编码字符

上图中的字符串 'you',经过转换后,得到的编码为: 'eW91'

当3个字符进行Base64转换编码后,最后变成了4个字符。因为每个6比特位,都补了2个0,变成8比特位,对应1字节

正常情况下,Base64编码的数据体积通常比原数据的体积大三分之一

= 等号

当长度不是 3 的倍数时,实际都会在后面补0,直到有24个二进制位为止

常见应用

  • 图片处理,基于 DataURL 方式,可以减少请求数

    • Data URL 由 data:前缀MIME类型(表明数据类型)base64标志位(如果是文本,则可选)以及 数据本身 四部分组成。 具体的格式:data:[<mime type>][;base64],<data>。 这里的第四部分 <data> 数据本身,就是一个Base64字符串

    • <img src="......Ii8+PC9nPjwvc3ZnPg==">
      ​
      .icon {
        background: url(......Ii8+PC9nPjwvc3ZnPg==);
      }
  • 文件读取

    • FileReader 的API,用来读取文件的数据,可以通过它的 readAsDataURL() 方法,将文件数据读取为Base64编码的字符串数据

    • let reader = new FileReader()
      reader.onload = () => {
        let base64Img = reader.result
      };
      reader.readAsDataURL(file)
  • Canvas 生成图片

    • Canvas本质上是一个位图图像,它有提供 toDataURL() 方法,将画布导出生成为一张图片,该图片将以Base64编码的格式进行保存

    • const dataUrl = canvasEl.toDataURL()
  • 其它

    • 特殊数据传输、简单编码和加密、代码混淆

参考

深入理解JavaScript中的Base64编码字符串_javascript技巧_脚本之家

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值