网络标准之:IANA定义的传输编码

简介: 网络标准之:IANA定义的传输编码

目录



简介


不同的系统或者协议可以接受的数据类型是不同的,如果要在那些不支持现有数据格式的系统或者协议中进行数据传输的话,就需要进行数据转换。


IANA的全称是The Internet Assigned Numbers Authority,也叫做互联网数字分配机构,是一个负责协调互联网的事务让Internet正常运作的机构。它定义了几个transfer encodings方式。


今天将会给大家详细讲解这几种方式的由来和使用场景。


IANA的传输编码方式


根据IANA的定义,有下面几个transfer encodings方式:


Name Reference
7bit [RFC2045]
8bit [RFC2045]
binary [RFC2045]
quoted-printable [RFC2045]
base64 [RFC2045]


这些传输编码方式都是什么意思呢?接下来一一讲述。


7bit


我们知道计算机的第一个字符编码就是ASCII编码,它表示的范围是从0到127。一个字节是8位,0到127意味着ASCII编码只使用7bits,这也就是7bit的由来。


对于有些协议或者系统来说,他们只支持ASCII编码,如果传输的数据范围超过了7bit,则会出现异常。


8bit


7bit在使用中有很大的限制,因为对于常用的Unicode编码来说,通常会使用2-4个字节作为信息的载体,如果是7bit的话,就会导致信息接收的不完整,从而失去数据原有的意义。


8bit的意思是,可以接收整个8bit的数据,也就是说数据可以按整个字节来传输。这样就没有传输的限制了。所以说8bit的应用会更加广泛,如果一个系统可以正确的接收8bit,那么我们可以称这个系统为8-bit clean 。


binary


是不是8bit就可以适用于所有的系统呢?我们要知道,8bit是按字节来进行传输的。所以对于格式更加紧凑的二进制流的话是不适用的。所以有一个专门的二进制消息格式binary来处理二进制信息。


quoted-printable


如果数据是binary格式的,但是系统又不支持binary格式该怎么办呢?


这时候我们就需要将binary转换成为text格式,这种转换叫做Binary-to-text encoding。其中quoted-printable和base64就是两种转换方式。


对于quoted-printable来说,就是将一个8-bit数据用7bit可读的字符来表示。虽然7bit可以表示0-127的范围,但是其中只有33 到 126是可读字符,其他的都不是可读字符。


那么quoted-printable是怎么转换的呢?


quoted-printable中,任何 8 位字节值都可以用 3 个字符来进行编码。=后面接两个16进制的数字。


比如对于ASCII的换页符12来说,转换过来就是=0C。 因为=是特殊的字符,所以等号也需要转义成=3D来表示。


对于可打印的ASCII字符,也就是33到126之间的十进制值,则不需要转义,直接表示他们自己即可。


ASCII 制表符和空格字符、十进制值9和32可以由它们自己表示,除非这些字符出现在编码行的末尾。在这种情况下,它们需要转义为=09(制表符)或 =20(空格),或者后跟 =(软换行符)作为编码行的最后一个字符。


另外Quoted-Printable 编码数据的一行不得超过76个字符。如果超出的话,可以根据需要添加软换行符。软换行符是由在编码行末尾添加=组成,软换行符不会在解码文本中显示为换行符。


base64


除了quoted-printable之外,还有一种常用的Binary-to-text encoding方式,叫做base64。


base64的原理是通过一个映射表,将二进制编码映射成为64个字符(26个小写字母+26个大写字母+10个数字+加号和斜杠)。


每个Base64字符可以表示6bits的数据,所以3个字节的数据可以用6个Base64字符来表示。


其映射表如下:


image.png


总结



以上就是IANA介绍的几种传输编码格式,大家学会了吗?

相关文章
|
2月前
|
安全 网络安全 数据安全/隐私保护
访问控制列表(ACL)是网络安全中的一种重要机制,用于定义和管理对网络资源的访问权限
访问控制列表(ACL)是网络安全中的一种重要机制,用于定义和管理对网络资源的访问权限。它通过设置一系列规则,控制谁可以访问特定资源、在什么条件下访问以及可以执行哪些操作。ACL 可以应用于路由器、防火墙等设备,分为标准、扩展、基于时间和基于用户等多种类型,广泛用于企业网络和互联网中,以增强安全性和精细管理。
288 7
|
2月前
|
安全 搜索推荐 网络安全
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
HTTPS协议是**一种通过计算机网络进行安全通信的传输协议
75 11
|
5月前
|
机器学习/深度学习 API 异构计算
7.1.3.2、使用飞桨实现基于LSTM的情感分析模型的网络定义
该文章详细介绍了如何使用飞桨框架实现基于LSTM的情感分析模型,包括网络定义、模型训练、评估和预测的完整流程,并提供了相应的代码实现。
|
5月前
|
负载均衡 安全 网络协议
|
1月前
|
机器学习/深度学习 Serverless 索引
分类网络中one-hot编码的作用
在分类任务中,使用神经网络时,通常需要将类别标签转换为一种合适的输入格式。这时候,one-hot编码(one-hot encoding)是一种常见且有效的方法。one-hot编码将类别标签表示为向量形式,其中只有一个元素为1,其他元素为0。
34 2
|
2月前
|
安全 网络安全 数据安全/隐私保护
访问控制列表(ACL)是网络安全管理的重要工具,用于定义和管理网络资源的访问权限。
访问控制列表(ACL)是网络安全管理的重要工具,用于定义和管理网络资源的访问权限。ACL 可应用于路由器、防火墙等设备,通过设定规则控制访问。其类型包括标准、扩展、基于时间和基于用户的ACL,广泛用于企业网络和互联网安全中,以增强安全性、实现精细管理和灵活调整。然而,ACL 也存在管理复杂和可能影响性能的局限性。未来,ACL 将趋向智能化和自动化,与其他安全技术结合,提供更全面的安全保障。
124 4
|
2月前
|
网络协议 网络安全 网络虚拟化
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算
本文介绍了十个重要的网络技术术语,包括IP地址、子网掩码、域名系统(DNS)、防火墙、虚拟专用网络(VPN)、路由器、交换机、超文本传输协议(HTTP)、传输控制协议/网际协议(TCP/IP)和云计算。通过这些术语的详细解释,帮助读者更好地理解和应用网络技术,应对数字化时代的挑战和机遇。
123 3
|
2月前
|
存储 数据安全/隐私保护 云计算
多云网络环境:定义、优势与挑战
多云网络环境:定义、优势与挑战
44 5
|
2月前
|
运维 物联网 网络虚拟化
网络功能虚拟化(NFV):定义、原理及应用前景
网络功能虚拟化(NFV):定义、原理及应用前景
125 3
|
2月前
|
网络协议 算法 网络性能优化
计算机网络常见面试题(一):TCP/IP五层模型、TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议
计算机网络常见面试题(一):TCP/IP五层模型、应用层常见的协议、TCP与UDP的区别,TCP三次握手、四次挥手,TCP传输可靠性保障、ARQ协议、ARP协议

热门文章

最新文章