【加密算法】Base64

一、简介
Base64是网络上最常见的用于传输8Bit字节码的编码方式之一,Base64就是一种基于64个可打印字符来表示二进制数据的方法。可查看RFC2045~RFC2049,上面有MIME的详细规范。
Base64编码是从二进制到字符的过程,可用于在HTTP环境下传递较长的标识信息。
 
标准的Base64并不适合直接放在URL里传输,因为URL编码器会把标准Base64中的“/”和“+”字符变为形如“%XX”的形式,而这些“%”号在存入数据库时还需要再进行转换,因为ANSI SQL中已将“%”号用作通配符。
为解决此问题,可采用一种用于URL的改进Base64编码,它不仅在末尾去掉填充的'='号,并将标准Base64中的“+”和“/”分别改成了“-”和“_”,这样就免去了在URL编解码和数据库存储时所要作的转换,避免了编码信息长度在此过程中的增加,并统一了数据库、表单等处对象标识符的格式。
另有一种用于正则表达式的改进Base64变种,它将“+”和“/”改成了“!”和“-”,因为“+”,“/”以及前面在IRCu中用到的“[”和“]”在正则表达式中都可能具有特殊含义。
此外还有一些变种,它们将“+/”改为“_-”或“._”(用作编程语言中的标识符名称)或“.-”(用于XML中的Nmtoken)甚至“_:”(用于XML中的Name)。
二、实现
/// <summary>
/// Base64加密解密
/// 密文用在url,注意+的转义
/// </summary>
public class Base64Helper
{
    /// <summary>
    /// Base64加密 可逆
    /// </summary>
    /// <param name="plaintext">待加密文本</param>
    /// <returns></returns>
    public static string Encrypt(string plaintext)
    {
        if (String.IsNullOrEmpty(plaintext))
        {
            throw new ArgumentNullException("明文不能为空");
        }

        byte[] data = Encoding.UTF8.GetBytes(plaintext);
        return Convert.ToBase64String(data);
    }

    /// <summary>
    /// Base64解密
    /// </summary>
    /// <param name="ciphertext">密文</param>
    /// <returns></returns>
    public static string Decrypt(string ciphertext)
    {
        if (String.IsNullOrEmpty(ciphertext))
        {
            throw new ArgumentNullException("密文不能为空");
        }
        byte[] data = Convert.FromBase64String(ciphertext);
        return Encoding.UTF8.GetString(data);
    }
}

 

posted @ 2018-12-11 16:18  a boy  阅读(218)  评论(0编辑  收藏  举报