美文网首页
Base64原理

Base64原理

作者: xiaduobao | 来源:发表于2018-05-04 16:26 被阅读0次

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

        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   
      15 P  32 g   49 x
      16 Q  33 h   50 y
    

    因为,Base64将三个字节转化成四个字节,因此Base64编码后的文本,会比原文本大出三分之一左右。

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

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

    相关文章

      网友评论

          本文标题:Base64原理

          本文链接:https://www.haomeiwen.com/subject/chodrftx.html