加密,解密算法

    private SymmetricAlgorithm mCSP;  //声明对称算法变量
    private const string CIV = "Mi56/+4Zujhy12se6Yjy111A";  //初始化向量
    private const string CKEY = "jkHuIy9D/9i="; //密钥(常量)

    //其中CIV里面的值可以修改的

   //CKEY也是可以改变的  ,改变之后的加密的值也会随着改变

//加密算法

  ICryptoTransform ct; //定义基本的加密转换运算
        MemoryStream ms; //定义内存流
        CryptoStream cs; //定义将内存流链接到加密转换的流
        byte[] byt;

        //CreateEncryptor创建(对称数据)加密对象
        mCSP = new DESCryptoServiceProvider();
        ct = mCSP.CreateEncryptor(Convert.FromBase64String(CKEY), Convert.FromBase64String(CIV)); //用指定的密钥和初始化向量创建对称数据加密标准

        byt = Encoding.UTF8.GetBytes(Value); //将Value字符转换为UTF-8编码的字节序列

        ms = new MemoryStream(); //创建内存流
        cs = new CryptoStream(ms, ct, CryptoStreamMode.Write); //将内存流链接到加密转换的流
        cs.Write(byt, 0, byt.Length); //写入内存流
        cs.FlushFinalBlock(); //将缓冲区中的数据写入内存流,并清除缓冲区
        cs.Close(); //释放内存流

        return Convert.ToBase64String(ms.ToArray()); //将内存流转写入字节数组并转换为string字符

//解密算法

 ICryptoTransform ct; //定义基本的加密转换运算
        MemoryStream ms; //定义内存流
        CryptoStream cs; //定义将数据流链接到加密转换的流
        byte[] byt;

        mCSP = new DESCryptoServiceProvider();
        ct = mCSP.CreateDecryptor(Convert.FromBase64String(CKEY), Convert.FromBase64String(CIV)); //用指定的密钥和初始化向量创建对称数据解密标准
        byt = Convert.FromBase64String(Value); //将Value(Base 64)字符转换成字节数组

        ms = new MemoryStream();
        cs = new CryptoStream(ms, ct, CryptoStreamMode.Write);
        cs.Write(byt, 0, byt.Length);
        cs.FlushFinalBlock();
        cs.Close();

        return Encoding.UTF8.GetString(ms.ToArray()); //将字节数组中的所有字符解码为一个字符串

posted @ 2011-09-23 17:18  That's me  阅读(205)  评论(0编辑  收藏  举报