1、前言

在我之前的博客中,介绍有关ASCII的相关知识

  • 计算机相关知识——字符编码中ASCII、Unicode和UTF-8的相关知识

中间有时会提到如何转换

  • JS学习笔记——window对象的函数btoa和atob

但是对于Base64的概念,但没有细说,所以这期来简单聊聊Base64编码。

2、为什么使用Base64

我们知道,Ascii码的128~255之间的值是不可见字符。在网络上交换数据时,比如从A地传到B地,往往要经过多个路由设备,由于不同的设备对字符的处理方式有一些不同,这样那些不可见字符就有可能被处理错误,这是不利于传输的。所以就先把数据转为Base64编码,统统变成可见字符,这样出错的可能性就大降低了。

同时base64作为网络上最常见的用于传输8bit字节代码的编码方式之一。有时我们需要把二进制数据编码为适合放在URL中的形式。这时采用base64编码具有不可读性,即所编码的数据不会被人直接看出。除此之外,还可以放在请求头响应头进行传输。

3、Base64的概念

Base64 就是指64个字符,包括大小写字母[A-Z、a-z]阿拉伯数字[0-9],还有两个字符[+、/],还有一个表示后缀的字符 [ = ],Base64就是指只能传输这64个字符

【注意】实际上Base64是65个字符

4、Base64的原理

4.1、编码规则

ASCII码, ASCII码的范围是0-127,其中0-31和127是控制字符,共33个。其余95个,即32-126可打印字符,包括数字、大小写字母常用符号等。Base64 就是将 ASCII码 用 Base64位字符表示

编码规则:

  • 第一步:将每3个字符作为一组,一共是24个二进制位
  • 第二步:将这24个二进制位分为4组,每个组有6个二进制位
  • 第三步:在每组前面加两个00,扩展成32个二进制位,即4个字符
  • 第四步:根据下表,得到扩展后的每个字节的对应符号,这就是Base64的编码值

4.2、编码示例

(1)Base64编码实例一:

将字符串“dog"转为Base64编码:

  • 第一步:d: ASCII值 100 ,二进制为 0110 0100;o: ASCII值 111 ,二进制为 0110 1111;g: ASCII值 103,二进制为 0110 0111(ASCII码可以上网搜那张对应表)
  • 第二步:将这24个二进制位 :0110 0100 0110 1111 0110 0111 ,分为4组:011001 000110 111101 100111
  • 第三步:每组前面加两个00,即:00011001 00000110 00111101 00100111
  • 第四步:查找对应的码值分别为:25、6、61、39查找上表,可以知道得到编码后的字符串为:ZG9n,所以字符串“dog”对应的Base64码值为“ZG9n”

(2)Base64编码实例二:

将字符串“Man"转为Base64编码,(这次我们以图来演示如何转换):
从上述两个例子可以得出结论:

  • 6和8的最小公倍数是24,所以Base64 需要6个二进制位表示 ASCII8个二进制位,显然,我们需要补0
  • 这样 4个Base64编码的6bit字符刚好能够表示3个传统的Ascii编码的8bit字符
  • base64编码传输会使得信息变大数据体积通常是原数据的体积4/3

4.3、特殊情况

上面我们的例子都是3个字符的情况,那如果不满3个,该怎么做?

(1)2个字节的情况:将这2个字节的一共16个二进制位,按照上面的规则,转成三组(6,6,4),最后一组除了前面加两个0以外,后面也要加两个0。这样得到一个三位的Base64编码,再在末尾补上一个"="号。
比如:“Ma"这个字符串是两个字节,可以转化成三组00010011、00010110、00000100以后,对应Base64值分别为T、W、E,再补上一个”="号,因此"Ma"的Base64编码就是TWE=。

(2)1个字节的情况:将这1个字节的8个二进制位,按照上面的规则转成2组(6,2),最后一组除了前面加二个0以外,后面再加4个0。这样得到一个二位的Base64编码,再在末尾补上两个"="号。
比如:“M"这个字母是一个字节,可以转化为二组00010011、00010000,对应的Base64值分别为T、Q,再补上二个”="号,因此"M"的Base64编码就是TQ==。

如果上述文字理解起来比较麻烦,可以参考下图:

4.4、加码过程

Base64解码的过程比较简单。去掉末尾的等号=。剩下的Base64字符,每8bit组成一个8bit字节,最后剩余不足8位的丢弃即可

5、Base64的作用

  • Base64编码是从二进制 ------> 字符的过程
  • 采用Base64编码具有不可读性,需要解码后才能阅读。但是Base64不是加密,只是一种可被翻译的编码
  • Base64编码可用于在HTTP环境下传递较长的标识信息,用作HTTP表单HTTP GET URL中的参数
  • 当需要把二进制数据放到url中时,采用base64具有不可读性比较合适

6、Base64的使用场景

6.1、图片的Base64编码

我们有时会看到,一些图片的地址并不是一个网络地址,而是一串字符串(如下图红框所示),这就是用Base64来表示该图片的地址。

图片的 base64 编码就是将一张图片数据编码成一串字符串,使用该字符串表示图片,从而无需图片地址

这样做有什么意义呢?我们知道,我们所看到的网页上的每一个图片,都是需要消耗一个 http 请求下载而来的。要是图片的下载不用向服务器发出请求,而可以随着 HTML 的下载同时下载到本地那就太好了,而 base64 正好就可以满足。这里等于把图片变为一串编码,直接嵌在html里传递给了浏览器,浏览器不用再次请求图片了

编码之后的字符串可以直接内联到HTML中显示,比如,我们一些体积比较小的图片,(注意:是图片足够小的情况下),就可以转换成 Base64编码直接插入到图片的 src 路径中。

在css里面的写法:

#xxx_xxx {background: url(…EoqQqJKAIBaQOVKHAXr3t7txgBjboSvB8EpLoFZywOAo3LFE5lYs/QW9LT1TRk1V7S2xYJADs=) no-repeat center;
}

在html里面img标签中的写法:

<img src="…EoqQqJKAIBaQOVKHAXr3t7txgBjboSvB8EpLoFZywOAo3LFE5lYs/QW9LT1TRk1V7S2xYJADs=">

(小秘密

计算机相关知识——前端Base64编码解码的基础使用相关推荐

  1. 前端Base64编码知识,一文打尽

    原文: https://juejin.cn/post/6989391487200919566 作者: 云的世界 掘金专栏: 前端基础进阶 健康满分 关注并将「趣谈前端」设为星标 每天定时分享技术干货/ ...

  2. 一些Base64编码/解码及数据压缩/解压方面的知识

    一.Base64编码/解码 一般用到的是Delphi自带的单元EncdDecd,当然还有第三方提供的单元或控件,其中我所接触到的认为比较好的有Indy的TIdMimeEncode / TIdMimeD ...

  3. delphi Base64编码/解码及数据压缩/解压知识

    一.Base64编码/解码 一般用到的是Delphi自带的单元EncdDecd,当然还有第三方提供的单元或控件,其中我所接触到的认为比较好的有Indy的TIdMimeEncode / TIdMimeD ...

  4. 原来浏览器原生支持JS Base64编码解码

    原来浏览器原生支持JS Base64编码解码 转载来源:https://www.zhangxinxu.com/wordpress/2018/08/js-base64-atob-btoa-encode- ...

  5. Delphi Base64编码/解码及ZLib压缩/解压

    最近在写的程序与SOAP相关,所以用到了一些Base64编码/解码及数据压缩/解压方面的知识. 在这里来作一些总结: 一.Base64编码/解码 一般用到的是Delphi自带的单元EncdDecd,当 ...

  6. Python 图片数据MYSQL存取(BASE64编码解码)

    Python 图片数据MYSQL存取(BASE64编码解码) 1.相关python代码 #-*- coding:utf-8 -*-import pymysql import sys import ba ...

  7. javaweb网页上传图片并显示在页面上,并在服务端存到磁盘(base64编码解码)

    最近做一个web项目用到上传图片,于是根据个人的知识 及网上的搜集,将其总结于下: 上传图片时显示图片在页面  <input id="fileload"  type=&quo ...

  8. js base64 编码解码

    js base64 编码解码 encode decode,可以直接使用 function Base64() {// private property_keyStr = "ABCDEFGHIJ ...

  9. python使用base64编码解码数据

    python使用base64编码解码数据 base64模块是用来作base64编码解码,常用于小型数据的传输.编码后的数据是一个字符串,其包括a-z.A-Z.0-9./.+共64个字符,即可用6个字节 ...

  10. java svgbase64转byte_java 图片进行base64 编码解码

    java 图片进行base64 编码解码 刘振兴 代码分享 2017年06月07日 10555 2条评论 import sun.misc.BASE64Decoder; import sun.misc. ...

最新文章

  1. Android中的service全面总结
  2. 怎么检测JDK环境变量是否配置正确
  3. Tomcat8.0 JDK1.8 的详细配置 Win10
  4. python心得体会300字_有没有简单一点的 Python 小例子或小项目?
  5. hdu3697(贪心+暴力)
  6. defined 函数使用
  7. fn:replace()函数
  8. JeecgBoot 连接达梦数据库
  9. js室内地图开发_如何组件化开发WebGIS系统
  10. splay详解(三)
  11. android 车牌字符分割,车牌识别 之 字符分割
  12. Linux cppcheck使用
  13. c语言为什么要使用short类型,为什么c语言中short的表示范围是-32768~32767?(转)...
  14. 《可复制的领导力》——樊登书摘
  15. linux内核网络队列,Linux 内核网络协议栈 ------ 清理重传队列中函数 tcp_clean_rtx_queue...
  16. win10系统暴雪战网连不上服务器,win10系统暴雪战网无法登陆的解决方法
  17. BI相关的内容---BI是什么,主要工作的内容有哪些?
  18. Spectral-based graph convolutional neural network
  19. OGC入门学习专栏(2.1) - SWE通用数据模型编码标准(写完所有小节再合)
  20. 2021年全国程序员工资出炉,想要年薪60万,难不难?网友,扎心了

热门文章

  1. android微信认证失败怎么办,微信登陆好友头像验证失败该怎么办?
  2. 我们整理了20个Python项目,送给正在求职的你
  3. vue中使用svg矢量图
  4. kali linux无线驱动安装,Kali Linux安装 WIFI无线网卡驱动 教程
  5. html图像缩小失真,图像放大和缩小不失真的方法!
  6. 一炉真香起静中开鸿蒙翻译,【真 香】_古籍全文检索_诗词名句网
  7. 系统集成项目经理申报
  8. 计算机房的红蜘蛛软件怎么取消,如何脱离学校机房的红蜘蛛控制软件的控制?...
  9. python除法程序_Python中的除法
  10. 同属开源Linux 移动市场MeeGo独到之秘