C#DES加密解密的實(shí)現(xiàn)實(shí)例淺析
C# DES加密解密的實(shí)現(xiàn),DES算法為密碼體制中的對稱密碼體制,由IBM公司研制的對稱密碼體制加密算法。其核心為密鑰長度為56位,明文按64位進(jìn)行分組,將分組后的明文組和56位的密鑰按位替代或交換的方法形成密文組的加密方法。
C# DES加密解密的實(shí)現(xiàn)實(shí)例:
C# DES加密解密之名稱空間 :
- using System;
- using System.Security.Cryptography;
- using System.IO;
- using System.Text;
C# DES加密解密之方法 :
- //加密方法
- publicstring Encrypt(string pToEncrypt, string sKey)
- {
- DESCryptoServiceProvider des = new DESCryptoServiceProvider();
- //把字符串放到byte數(shù)組中
- //原來使用的UTF8編碼,我改成Unicode編碼了,不行
- byte[] inputByteArray = Encoding.Default.GetBytes(pToEncrypt);
- //byte[] inputByteArray=Encoding.Unicode.GetBytes(pToEncrypt);
C# DES加密解密之建立加密對象的密鑰和偏移量
- //原文使用ASCIIEncoding.ASCII方法的GetBytes方法
- //使得輸入密碼必須輸入英文文本
- des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
- des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
- MemoryStream ms = new MemoryStream();
- CryptoStream cs = new CryptoStream(
- ms, des.CreateEncryptor(),CryptoStreamMode.Write);
- //Write the byte array into the crypto stream
- //(It will end up in the memory stream)
- cs.Write(inputByteArray, 0, inputByteArray.Length);
- cs.FlushFinalBlock();
- //Get the data back from the memory stream, and into a string
- StringBuilder ret = new StringBuilder();
- foreach(byte b in ms.ToArray())
- {
- //Format as hex
- ret.AppendFormat("{0:X2}", b);
- }
- ret.ToString();
- return ret.ToString();
- }
C# DES加密解密之解密方法
- publicstring Decrypt(string pToDecrypt, string sKey)
- {
- DESCryptoServiceProvider des = new DESCryptoServiceProvider();
- //Put the input string into the byte array
- byte[] inputByteArray = new byte[pToDecrypt.Length / 2];
- for(int x = 0; x < pToDecrypt.Length / 2; x++)
- {
- int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));
- inputByteArray[x] = (byte)i;
- }
C# DES加密解密之建立加密對象的密鑰和偏移量,此值重要,不能修改
- des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
- des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
- MemoryStream ms = new MemoryStream();
- CryptoStream cs = new CryptoStream(ms,
- des.CreateDecryptor(),CryptoStreamMode.Write);
- //Flush the data through the crypto stream into the memory stream
- cs.Write(inputByteArray, 0, inputByteArray.Length);
- cs.FlushFinalBlock();
- //Get the decrypted data back from the memory stream
- //建立StringBuild對象,
- //CreateDecrypt使用的是流對象,必須把解密后的文本變成流對象
- StringBuilder ret = new StringBuilder();
- return System.Text.Encoding.Default.GetString(ms.ToArray());
- }
C# DES加密解密的實(shí)例解析就向你介紹到這里,希望你對C# DES加密解密有所了解,對你應(yīng)用C# DES加密解密有所幫助。
【編輯推薦】