加密解密,关键点

直接上代码:

public string EnCryptText(string text, byte[] desKey, byte[] desIv)
        {
            MemoryStream inputStream = new MemoryStream();
            DESCryptoServiceProvider provider = new DESCryptoServiceProvider();
            CryptoStream cryptStream = new CryptoStream(inputStream, provider.CreateEncryptor(desKey, desIv), CryptoStreamMode.Write);
            var bytes = Encoding.Default.GetBytes(text);
            cryptStream.Write(bytes, 0, bytes.Length);
            cryptStream.FlushFinalBlock();//this code is important;
            byte[] byteArr = inputStream.ToArray();
            string result = Convert.ToBase64String(byteArr);
            return result;
        }

        public string DeCryptText(string text, byte[] desKey, byte[] desIv)
        {
            MemoryStream inputStream = new MemoryStream();
            DESCryptoServiceProvider provider = new DESCryptoServiceProvider();
            CryptoStream cryptStream = new CryptoStream(inputStream, provider.CreateDecryptor(desKey, desIv), CryptoStreamMode.Write);
            byte[] byteArr = Convert.FromBase64String(text);//之前用base64编码的,此时要用base64解码
            cryptStream.Write(byteArr, 0, byteArr.Length);
            cryptStream.FlushFinalBlock();
            byte[] arr = inputStream.ToArray();
            string result = Encoding.Default.GetString(arr);
            return result;
        }

此为字符串加密,可用于网络传输之类。

流程:

Des加密->转换为base64编码的字符串(为了传输)->传输->收到base64编码的字符串->解base64编码字符串为byte数组->解密->获得明文

附上base64的编码说明

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

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

posted @ 2016-01-15 17:06  如虎添翼  阅读(258)  评论(0编辑  收藏  举报