Base64编码

Base64

1.什么是Base64?
按照RFC2045的定义,Base64被定义为: Base64内容传送编码被设计用来把任意序列的8位字节描述为一种不易被人直接识别的形式,这种加密方式主要就是“防君子不防小人”。即达到一眼望去完全看不出内容即可。
2. 算法详解

    Base64编码要求把3个8位字节(3*8=24)转化为4个6位的字节(4*6=24),之后在6位的前面补两个0,形成8位一个字节的形式。 如果剩下的字符不足3个字节,则用0填充,输出字符使用'=',因此编码后输出的文本末尾可能会出现1或2个'='。

具体转化形式间下图:
字符串“张3”
11010101 11000101 00110011

00110101 00011100 00010100 00110011

3. Base64编码表


为了保证所输出的编码位可读字符,Base64制定了一个编码表,以便进行统一转换。编码表的大小为2^6=64,这也是Base64名称的由来。



           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
      0         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

编码详解


1. 不加后补位的字符串“abC”


01100001 01100010 01000011
00011000 00010110 00001001 00000011

24       22       9        3

查表可以得到编码值为:“YWJD”。



2. 加后补位的字符串“ab”:



01100001 01100010
00011000 00010110 00001000 00000000

24       22       8        -


由于不够24个字节位,所以我们要加8个0字节位以凑够24个。“-”表示增加的补位,编码后应为“=”,所以可以得到编码后的字符串为“YWI=”。



3. 加后补位的字符串“a”:



01100001

00011000 00010000 00000000 00000000

24       16       -        -


同样,编码后的字符串为“YQ==”,只是这里出现了两个“=”。



你可能感兴趣的:(C++,c,算法,F#,C#)