zoukankan      html  css  js  c++  java
  • C#Base64编码

    一. Base64的编码规则

    Base64编码的思想是是采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节数组。以3个字节为一组。按顺序排列24 位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前补两个0凑足一个字节。这样就把一个3字节为一组的数据重新编码成了4个字节。当所要编码的数据的字节数不是3的整倍数,也就是说在分组时最后一组不够3个字节。这时在最后一组填充1到2个0字节。并在最后编码完成后在结尾添加1到2个 “=”。

    例:将对ABC进行BASE64编码:


    1、首先取ABC对应的ASCII码值。A(65)B(66)C(67);
    2、再取二进制值A(01000001)B(01000010)C(01000011);
     3、然后把这三个字节的二进制码接起来(010000010100001001000011);
    4、 再以6位为单位分成4个数据块,并在最高位填充两个0后形成4个字节的编码后的值,(00
    010000)(00010100)(00001001)(00000011),其中蓝色部分为真实数据;
     5、再把这四个字节数据转化成10进制数得(16)(20)(9)(3);
     6、最后根据BASE64给出的64个基本字符表,查出对应的ASCII码字符(Q)(U)(J)(D),这里的值实际就是数据在字符表中的索引。

    注:BASE64字符表:ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/

    二.解码规则

    解码过程就是把4个字节再还原成3个字节再根据不同的数据形式把字节数组重新整理成数据。

     

    三. C#中的实现

     

    Code

     

  • 相关阅读:
    C语言实现时间差、星期、天数算日期(转)
    windbg 源码调试设置
    Windbg调试命令详解
    突破session 0隔离 和 劫持exe注入(转自梦无极)
    debug : StartService failed, getlasterror = 0x7f(127) 转
    反调试技巧总结-原理和实现
    关于Win7 x64下过TP保护(内核层)(转)
    python将dict中的unicode打印成中文
    Python 获取接口数据,解析JSON,写入文件
    python提取网页中json数据
  • 原文地址:https://www.cnblogs.com/engine1984/p/1439648.html
Copyright © 2011-2022 走看看