发布网友 发布时间:2022-04-22 14:07
共3个回答
热心网友 时间:2022-04-19 07:33
Base是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045~RFC2049,上面有MIME的详细规范。Base编码可用于在HTTP环境下传递较长的标识信息。例如,在Java Persistence系统Hibernate中,就采用了Base来将一个较长的唯一标识符(一般为128-bit的UUID)编码为一个字符串,用作HTTP表单和HTTP GET URL中的参数。在其他应用程序中,也常常需要把二进制数据编码为适合放在URL(包括隐藏表单域)中的形式。此时,采用Base编码具有不可读性,即所编码的数据不会被人用肉眼所直接看到。
详情参见http://ke.baidu.com/view/469071.htm百度百科追问为什么电子邮件中会用到base呢?
追答因为早期的一些邮件服务器只支持文本信息,不支持二进制信息和文件。而base编码后的结果都是ASCII低128位,也就是都是纯文本的,适合用电子邮件来传送二进制数据
热心网友 时间:2022-04-19 08:51
base是一种编码,用6个二进位来表示一个字节。
按照RFC2045的定义,Base被定义为:Base内容传送编码被设计用来把任意序列的8位字节描述为一种不易被人直接识别的形式。
在Email的传送过程中,由于历史原因,Email只被允许传送ASCII字符,即一个8位字节的低7位。因此,如果您发送了一封带有非ASCII字符(即字节的最高位是1)的Email通过有“历史问题”的网关时就可能会出现问题。
网关可能会把最高位置为0!
热心网友 时间:2022-04-19 10:25
Base是网络上最常见的用于传输8Bit字节代码的编码方式之一,在发送电子邮件时,服务器认证的用户名和密码需要用Base编码,附件也需要用Base编码。
下面简单介绍Base算法的原理,由于代码太长就不在此贴出
Base要求把每三个8Bit的字节转换为四个6Bit的字节(3*8 = 4*6 = 24),然后把6Bit再添两位高位0,组成四个8Bit的字节,也就是说,转换后的字符串理论上将要比原来的长1/3。
转换后,我们用一个码表来得到我们想要的字符串(也就是最终的Base编码),这个表是这样的:
0 A 17 R 34 i 51 z
1 B 18 S 35 j 52 0
2 C 19 T 36 k 53 1
3 D 20 U 37 l 54 2
4 E 21 V 38 m 55 3
5 F 22 W 39 n 56 4
6 G 23 X 40 o 57 5
7 H 24 Y 41 p 58 6
8 I 25 Z 42 q 59 7
9 J 26 a 43 r 60 8
10 K 27 b 44 s 61 9
11 L 28 c 45 t 62 +
12 M 29 d 46 u 63 /
13 N 30 e 47 v
14 O 31 f 48 w (pad) =
15 P 32 g 49 x
16 Q 33 h 50 y
原文的字节最后不够3个的地方用0来补足,转换时Base编码用=号来代替。这就是为什么有些Base编码会以一个或两个等号结束的原因,但等号最多只有两个。
举一个例子,abc经过Base编码以后的结果是YWJj.
发邮件的时候所写的信息自动在后台转换然后传输...