spacebound 中各种加密算法实现 - 菏泽39资讯网 ag视讯试玩|开户,ag环亚集团人工计划|优惠,环亚娱乐ag88旗|首页

spacebound 中各种加密算法实现

文章作者:小 巫 | 2019-10-19 21:31:02
字体大小:
#region 利用MD5对字符串进行加密 &nbp; &nbp; &nbp; &nbp; /// &nbp; &nbp; &nbp; &nbp; &nbp; &nbp; /// &nbp; 利用MD5对字符串进行加密&nbp; &nbp; &nbp; &nbp; &nbp; /// &nbp; &nbp; &n

#region 利用MD5对字符串进行加密
? ? ? ? /// ?

?
? ? ? ? /// ? 利用MD5对字符串进行加密?
? ? ? ? /// ?
?
? ? ? ? /// ? 待加密的字符串 ?
? ? ? ? /// ? 返回加密后的字符串 ?
? ? ? ? public static string EncryptMD5(string encryptString)
? ? ? ? {
? ? ? ? ? ? MD5CryptoServiceProvider md5Hasher = new MD5CryptoServiceProvider();
? ? ? ? ? ? UTF8Encoding Encode = new UTF8Encoding();
? ? ? ? ? ? byte[] HashedBytes = puteHash(Encode.GetBytes(encryptString));
? ? ? ? ? ? return Encode.GetString(HashedBytes);
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #region RSA

? ? ? ? #region rsa解密
? ? ? ? ///


? ? ? ? /// rsa解密
? ? ? ? ///

? ? ? ? /// 加密后字符串字符串
? ? ? ? /// 加密key
? ? ? ? ///
? ? ? ? public static string RSADecrypt(string s, string key)
? ? ? ? {
? ? ? ? ? ? string result = null;
? ? ? ? ? ? if (string.IsNullOrEmpty(s)) throw new ArgumentException("An empty string value cannot be encrypted.");
? ? ? ? ? ? if (string.IsNullOrEmpty(key)) throw new ArgumentException("Cannot decrypt using an empty key. Please supply a decryption key.");
? ? ? ? ? ? CspParameters cspp = new CspParameters();
? ? ? ? ? ? cspp.KeyContainerName = key;
? ? ? ? ? ? RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(cspp);
? ? ? ? ? ? rsa.PersistKeyInCsp = true;
? ? ? ? ? ? string[] decryptArray = s.Split(new string[] { "-" }, StringSplitOptions.None);
? ? ? ? ? ? byte[] decryptByteArray = Array.ConvertAll(decryptArray, (a => Convert.ToByte(byte.Parse(a, System.Globalization.NumberStyles.HexNumber))));
? ? ? ? ? ? byte[] bytes = rsa.Decrypt(decryptByteArray, true);
? ? ? ? ? ? result = System.Text.UTF8Encoding.UTF8.GetString(bytes);
? ? ? ? ? ? return result;
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #region rsa加密
? ? ? ? ///


? ? ? ? /// rsa加密
? ? ? ? ///

? ? ? ? /// 要加密的字符串
? ? ? ? /// 加密key
? ? ? ? ///
? ? ? ? public static string RSAEncrypt(string s, string key)
? ? ? ? {
? ? ? ? ? ? if (string.IsNullOrEmpty(s)) throw new ArgumentException("An empty string value cannot be encrypted.");
? ? ? ? ? ? if (string.IsNullOrEmpty(key)) throw new ArgumentException("Cannot encrypt using an empty key. Please supply an encryption key.");
? ? ? ? ? ? CspParameters cspp = new CspParameters();
? ? ? ? ? ? cspp.KeyContainerName = key;
? ? ? ? ? ? RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(cspp);
? ? ? ? ? ? rsa.PersistKeyInCsp = true;
? ? ? ? ? ? byte[] bytes = rsa.Encrypt(System.Text.UTF8Encoding.UTF8.GetBytes(s), true);
? ? ? ? ? ? return BitConverter.ToString(bytes);
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #endregion

? ? ? ? #region DES

? ? ? ? #region DES加密字符串
? ? ? ? /// ?

?
? ? ? ? /// ? DES加密字符串?
? ? ? ? /// ?
?
? ? ? ? /// ? 待加密的字符串 ?
? ? ? ? /// ? 加密密钥,要求为8位 ?
? ? ? ? /// ? 加密成功返回加密后的字符串,失败返回源串 ?
? ? ? ? public static string EncryptDES(string encryptString, string encryptKey)
? ? ? ? {
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? byte[] rgbKey = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8));
? ? ? ? ? ? ? ? byte[] rgbIV = Keys;
? ? ? ? ? ? ? ? byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
? ? ? ? ? ? ? ? DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
? ? ? ? ? ? ? ? MemoryStream mStream = new MemoryStream();
? ? ? ? ? ? ? ? CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
? ? ? ? ? ? ? ? cStream.Write(inputByteArray, 0, inputByteArray.Length);
? ? ? ? ? ? ? ? cStream.FlushFinalBlock();
? ? ? ? ? ? ? ? return Convert.ToBase64String(mStream.ToArray());
? ? ? ? ? ? }
? ? ? ? ? ? catch
? ? ? ? ? ? {
? ? ? ? ? ? ? ? return encryptString;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #region DES解密字符串
? ? ? ? /// ?

?
? ? ? ? /// ? DES解密字符串?
? ? ? ? /// ?
?
? ? ? ? /// ? 待解密的字符串 ?
? ? ? ? /// ? 解密密钥,要求为8位,和加密密钥相同 ?
? ? ? ? /// ? 解密成功返回解密后的字符串,失败返源串 ?
? ? ? ? public static string DecryptDES(string decryptString, string decryptKey)
? ? ? ? {
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? byte[] rgbKey = Encoding.UTF8.GetBytes(decryptKey);
? ? ? ? ? ? ? ? byte[] rgbIV = Keys;
? ? ? ? ? ? ? ? byte[] inputByteArray = Convert.FromBase64String(decryptString);
? ? ? ? ? ? ? ? DESCryptoServiceProvider DCSP = new DESCryptoServiceProvider();
? ? ? ? ? ? ? ? MemoryStream mStream = new MemoryStream();
? ? ? ? ? ? ? ? CryptoStream cStream = new CryptoStream(mStream, DCSP.CreateDecryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
? ? ? ? ? ? ? ? cStream.Write(inputByteArray, 0, inputByteArray.Length);
? ? ? ? ? ? ? ? cStream.FlushFinalBlock();
? ? ? ? ? ? ? ? return Encoding.UTF8.GetString(mStream.ToArray());
? ? ? ? ? ? }
? ? ? ? ? ? catch
? ? ? ? ? ? {
? ? ? ? ? ? ? ? return decryptString;
? ? ? ? ? ? }
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #endregion

? ? ? ? #region 3DES-1

? ? ? ? #region 3DES加密
? ? ? ? ///


? ? ? ? /// 3DES加密
? ? ? ? ///

? ? ? ? /// 需要加密的字符串
? ? ? ? /// 加密key
? ? ? ? ///
? ? ? ? public static string DES3Encrypt(string strString, string strKey)
? ? ? ? {
? ? ? ? ? ? TripleDESCryptoServiceProvider DES = new TripleDESCryptoServiceProvider();
? ? ? ? ? ? MD5CryptoServiceProvider hashMD5 = new MD5CryptoServiceProvider();

? ? ? ? ? ? DES.Key = puteHash(Encoding.Default.GetBytes(strKey));
? ? ? ? ? ? DES.Mode = CipherMode.ECB;

? ? ? ? ? ? ICryptoTransform DESEncrypt = DES.CreateEncryptor();

? ? ? ? ? ? byte[] Buffer = Encoding.Default.GetBytes(strString);
? ? ? ? ? ? return Convert.ToBase64String(DESEncrypt.TransformFinalBlock(Buffer, 0, Buffer.Length));
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #region 3DES解密
? ? ? ? ///


? ? ? ? /// 3DES解密
? ? ? ? ///

? ? ? ? /// 解密字符串
? ? ? ? /// 解密key
? ? ? ? ///
? ? ? ? public static string DES3Decrypt(string strString, string strKey)
? ? ? ? {
? ? ? ? ? ? TripleDESCryptoServiceProvider DES = new TripleDESCryptoServiceProvider();
? ? ? ? ? ? MD5CryptoServiceProvider hashMD5 = new MD5CryptoServiceProvider();

? ? ? ? ? ? DES.Key = puteHash(Encoding.Default.GetBytes(strKey)); DES.Mode = CipherMode.ECB;
? ? ? ? ? ? ICryptoTransform DESDecrypt = DES.CreateDecryptor();
? ? ? ? ? ? string result = "";
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? byte[] Buffer = Convert.FromBase64String(strString);
? ? ? ? ? ? ? ? result = Encoding.Default.GetString(DESDecrypt.TransformFinalBlock(Buffer, 0, Buffer.Length));
? ? ? ? ? ? }
? ? ? ? ? ? catch (System.Exception e)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? throw (new System.Exception("null", e));
? ? ? ? ? ? }
? ? ? ? ? ? return result;
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #endregion

? ? ? ? #region RC2

? ? ? ? #region RC2加密
? ? ? ? ///


? ? ? ? /// RC2加密
? ? ? ? ///

? ? ? ? /// 待加密的密文
? ? ? ? /// 密匙(必须为5-16位)
? ? ? ? ///
? ? ? ? public static string RC2Encrypt(string encryptString, string encryptKey)
? ? ? ? {
? ? ? ? ? ? string returnValue;
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? byte[] temp = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
? ? ? ? ? ? ? ? RC2CryptoServiceProvider rC2 = new RC2CryptoServiceProvider();
? ? ? ? ? ? ? ? byte[] byteEncryptString = Encoding.Default.GetBytes(encryptString);
? ? ? ? ? ? ? ? MemoryStream memorystream = new MemoryStream();
? ? ? ? ? ? ? ? CryptoStream cryptoStream = new CryptoStream(memorystream, rC2.CreateEncryptor(Encoding.Default.GetBytes(encryptKey), temp), CryptoStreamMode.Write);
? ? ? ? ? ? ? ? cryptoStream.Write(byteEncryptString, 0, byteEncryptString.Length);
? ? ? ? ? ? ? ? cryptoStream.FlushFinalBlock();
? ? ? ? ? ? ? ? returnValue = Convert.ToBase64String(memorystream.ToArray());

? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? throw ex;
? ? ? ? ? ? }
? ? ? ? ? ? return returnValue;

? ? ? ? }
? ? ? ? #endregion

? ? ? ? #region RC2解密
? ? ? ? ///


? ? ? ? /// RC2解密
? ? ? ? ///

? ? ? ? /// 密文
? ? ? ? /// 密匙(必须为5-16位)
? ? ? ? ///
? ? ? ? public static string RC2Decrypt(string decryptString, string decryptKey)
? ? ? ? {
? ? ? ? ? ? string returnValue;
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? byte[] temp = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
? ? ? ? ? ? ? ? RC2CryptoServiceProvider rC2 = new RC2CryptoServiceProvider();
? ? ? ? ? ? ? ? byte[] byteDecrytString = Convert.FromBase64String(decryptString);
? ? ? ? ? ? ? ? MemoryStream memoryStream = new MemoryStream();
? ? ? ? ? ? ? ? CryptoStream cryptoStream = new CryptoStream(memoryStream, rC2.CreateDecryptor(Encoding.Default.GetBytes(decryptKey), temp), CryptoStreamMode.Write);
? ? ? ? ? ? ? ? cryptoStream.Write(byteDecrytString, 0, byteDecrytString.Length);
? ? ? ? ? ? ? ? cryptoStream.FlushFinalBlock();
? ? ? ? ? ? ? ? returnValue = Encoding.Default.GetString(memoryStream.ToArray());
? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? throw ex;
? ? ? ? ? ? }
? ? ? ? ? ? return returnValue;
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #endregion

? ? ? ? #region 3DES-2

? ? ? ? #region 3DES 加密
? ? ? ? ///


? ? ? ? /// 3DES 加密
? ? ? ? ///

? ? ? ? /// 待加密密文
? ? ? ? /// 密匙1(长度必须为8位)
? ? ? ? /// 密匙2(长度必须为8位)
? ? ? ? /// 密匙3(长度必须为8位)
? ? ? ? ///
? ? ? ? public static string DES3Encrypt(string encryptString, string encryptKey1, string encryptKey2, string encryptKey3)
? ? ? ? {

? ? ? ? ? ? string returnValue;
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? returnValue = EncryptDES(encryptString, encryptKey3);
? ? ? ? ? ? ? ? returnValue = EncryptDES(returnValue, encryptKey2);
? ? ? ? ? ? ? ? returnValue = EncryptDES(returnValue, encryptKey1);

? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? throw ex;
? ? ? ? ? ? }
? ? ? ? ? ? return returnValue;

? ? ? ? }
? ? ? ? #endregion

? ? ? ? #region 3DES 解密
? ? ? ? ///


? ? ? ? /// 3DES 解密
? ? ? ? ///

? ? ? ? /// 待解密密文
? ? ? ? /// 密匙1(长度必须为8位)
? ? ? ? /// 密匙2(长度必须为8位)
? ? ? ? /// 密匙3(长度必须为8位)
? ? ? ? ///
? ? ? ? public static string DES3Decrypt(string decryptString, string decryptKey1, string decryptKey2, string decryptKey3)
? ? ? ? {

? ? ? ? ? ? string returnValue;
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? returnValue = DecryptDES(decryptString, decryptKey1);
? ? ? ? ? ? ? ? returnValue = DecryptDES(returnValue, decryptKey2);
? ? ? ? ? ? ? ? returnValue = DecryptDES(returnValue, decryptKey3);

? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? throw ex;
? ? ? ? ? ? }
? ? ? ? ? ? return returnValue;
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #endregion

? ? ? ? #region AES

? ? ? ? #region AES加密
? ? ? ? ///


? ? ? ? /// AES加密
? ? ? ? ///

? ? ? ? /// 待加密的密文
? ? ? ? /// 加密密匙
? ? ? ? ///
? ? ? ? public static string AESEncrypt(string encryptString, string encryptKey)
? ? ? ? {
? ? ? ? ? ? string returnValue;
? ? ? ? ? ? byte[] temp = Convert.FromBase64String("Rkb4jvUy/ye7Cd7k89QQgQ==");
? ? ? ? ? ? Rijndael AESProvider = Rijndael.Create();
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? byte[] byteEncryptString = Encoding.Default.GetBytes(encryptString);
? ? ? ? ? ? ? ? MemoryStream memoryStream = new MemoryStream();
? ? ? ? ? ? ? ? CryptoStream cryptoStream = new CryptoStream(memoryStream, AESProvider.CreateEncryptor(Encoding.Default.GetBytes(encryptKey), temp), CryptoStreamMode.Write);
? ? ? ? ? ? ? ? cryptoStream.Write(byteEncryptString, 0, byteEncryptString.Length);
? ? ? ? ? ? ? ? cryptoStream.FlushFinalBlock();
? ? ? ? ? ? ? ? returnValue = Convert.ToBase64String(memoryStream.ToArray());
? ? ? ? ? ? }

? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? throw ex;
? ? ? ? ? ? }

? ? ? ? ? ? return returnValue;

? ? ? ? }
? ? ? ? #endregion

? ? ? ? #region AES解密
? ? ? ? ///


? ? ? ? ///AES 解密
? ? ? ? ///

? ? ? ? /// 待解密密文
? ? ? ? /// 解密密钥
? ? ? ? ///
? ? ? ? public static string AESDecrypt(string decryptString, string decryptKey)
? ? ? ? {
? ? ? ? ? ? string returnValue = "";
? ? ? ? ? ? byte[] temp = Convert.FromBase64String("Rkb4jvUy/ye7Cd7k89QQgQ==");
? ? ? ? ? ? Rijndael AESProvider = Rijndael.Create();
? ? ? ? ? ? try
? ? ? ? ? ? {
? ? ? ? ? ? ? ? byte[] byteDecryptString = Convert.FromBase64String(decryptString);
? ? ? ? ? ? ? ? MemoryStream memoryStream = new MemoryStream();
? ? ? ? ? ? ? ? CryptoStream cryptoStream = new CryptoStream(memoryStream, AESProvider.CreateDecryptor(Encoding.Default.GetBytes(decryptKey), temp), CryptoStreamMode.Write);
? ? ? ? ? ? ? ? cryptoStream.Write(byteDecryptString, 0, byteDecryptString.Length);
? ? ? ? ? ? ? ? cryptoStream.FlushFinalBlock();
? ? ? ? ? ? ? ? returnValue = Encoding.Default.GetString(memoryStream.ToArray());
? ? ? ? ? ? }
? ? ? ? ? ? catch (Exception ex)
? ? ? ? ? ? {
? ? ? ? ? ? ? ? throw ex;
? ? ? ? ? ? }
? ? ? ? ? ? return returnValue;
? ? ? ? }
? ? ? ? #endregion

? ? ? ? #endregion

? ? ? ? #region DSA加密 暂没有实现
? ? ? ? public static string EncryptDSA(string encryptString, string key)
? ? ? ? {
? ? ? ? ? ? byte[] bytes = Encoding.ASCII.GetBytes(encryptString);
? ? ? ? ? ? //选择签名方式,有RSA和DSA?
? ? ? ? ? ? DSACryptoServiceProvider dsac = new DSACryptoServiceProvider();
? ? ? ? ? ? byte[] sign = dsac.SignData(bytes);
? ? ? ? ? ? //sign便是出来的签名结果。?
? ? ? ? ? ? return sign.ToString();
? ? ? ? }

? ? ? ? public static string DecryptDSA(string decryptString, string key)
? ? ? ? {
? ? ? ? ? ? return string.Empty;
? ? ? ? }
? ? ? ? #endregion
? ? }

首页 ag亚游登录|优惠| 明星| 奇闻| 职场| 综合| 科技| 网站地图| 手机站
申明:本站部分信息来自网络仅供参考,如有转载或引用文章涉及版权问题,请联系我们我们会尽快删除
蜀ICP备15003792号-1