C#可逆加密算法收集

  最近要用到这个顺带收集下
  以下是关于对称加密算法的C#实现代码,大家可以根据需要更改不同的算法,文中以Rijndael算法为例:view plaincopy to clipboardprint?
  using System;
  using System.IO;
  using System.Security.Cryptography;
  
  using System.Text;
  
  namespace DataCrypto
  {
  /// <summary>
  /// 对称加密算法类
  /// </summary>
  public class SymmetricMethod
  {
  
  private SymmetricAlgorithm mobjCryptoService;
  private string Key;
  /// <summary>
  /// 对称加密类的构造函数
  /// </summary>
  public SymmetricMethod()
  {
  mobjCryptoService = new RijndaelManaged();
  Key = "Guz(%&hj7x89H$yuBI0456FtmaT5&fvHUFCy76*h%(HilJ$lhj!y6&(*jkP87jH7";
  }
  /// <summary>
  /// 获得密钥
  /// </summary>
  /// <returns>密钥</returns>
  private byte[] GetLegalKey()
  {
  string sTemp = Key;
  mobjCryptoService.GenerateKey();
  byte[] bytTemp = mobjCryptoService.Key;
  int KeyLength = bytTemp.Length;
  if (sTemp.Length > KeyLength)
  sTemp = sTemp.Substring(0, KeyLength);
  else if (sTemp.Length < KeyLength)
  sTemp = sTemp.PadRight(KeyLength, ' ');
  return ASCIIEncoding.ASCII.GetBytes(sTemp);
  }
  /// <summary>
  /// 获得初始向量IV
  /// </summary>
  /// <returns>初试向量IV</returns>
  private byte[] GetLegalIV()
  {
  string sTemp = "E4ghj*Ghg7!rNIfb&95GUY86GfghUb#er57HBh(u%g6HJ($jhWk7&!hg4ui%$hjk";
  mobjCryptoService.GenerateIV();
  byte[] bytTemp = mobjCryptoService.IV;
  int IVLength = bytTemp.Length;
  if (sTemp.Length > IVLength)
  sTemp = sTemp.Substring(0, IVLength);
  else if (sTemp.Length < IVLength)
  sTemp = sTemp.PadRight(IVLength, ' ');
  return ASCIIEncoding.ASCII.GetBytes(sTemp);
  }
  /// <summary>
  /// 加密方法
  /// </summary>
  /// <param name="Source">待加密的串</param>
  /// <returns>经过加密的串</returns>
  public string Encrypto(string Source)
  {
  byte[] bytIn = UTF8Encoding.UTF8.GetBytes(Source);
  MemoryStream ms = new MemoryStream();
  mobjCryptoService.Key = GetLegalKey();
  mobjCryptoService.IV = GetLegalIV();
  ICryptoTransform encrypto = mobjCryptoService.CreateEncryptor();
  CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Write);
  cs.Write(bytIn, 0, bytIn.Length);
  cs.FlushFinalBlock();
  ms.Close();
  byte[] bytOut = ms.ToArray();
  return Convert.ToBase64String(bytOut);
  }
  /// <summary>
  /// 解密方法
  /// </summary>
  /// <param name="Source">待解密的串</param>
  /// <returns>经过解密的串</returns>
  public string Decrypto(string Source)
  {
  byte[] bytIn = Convert.FromBase64String(Source);
  MemoryStream ms = new MemoryStream(bytIn, 0, bytIn.Length);
  mobjCryptoService.Key = GetLegalKey();
  mobjCryptoService.IV = GetLegalIV();
  ICryptoTransform encrypto = mobjCryptoService.CreateDecryptor();
  CryptoStream cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Read);
  StreamReader sr = new StreamReader(cs);
  return sr.ReadToEnd();
  }
  }
  }

转载于:https://www.cnblogs.com/NetDeng/archive/2010/01/20/1652089.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RSA(Rivest-Shamir-Adleman)是一种非对称加密算法,用于加密和解密数据。C#中提供了对RSA算法的支持。下面是一个简单的示例代码,展示如何使用RSA算法进行加密和解密: ```csharp using System; using System.Security.Cryptography; using System.Text; public class RSADemo { public static void Main() { // 创建RSA实例 using (RSA rsa = RSA.Create()) { try { // 生成RSA的公钥和私钥对 RSAParameters publicKey; RSAParameters privateKey; rsa.KeySize = 2048; // 设置密钥长度 // 生成密钥对 publicKey = rsa.ExportParameters(false); privateKey = rsa.ExportParameters(true); // 要加密的数据 string dataToEncrypt = "Hello, RSA!"; // 加密数据 byte[] encryptedData = EncryptData(Encoding.UTF8.GetBytes(dataToEncrypt), publicKey); // 解密数据 byte[] decryptedData = DecryptData(encryptedData, privateKey); // 显示结果 Console.WriteLine("原始数据: {0}", dataToEncrypt); Console.WriteLine("加密后的数据: {0}", Convert.ToBase64String(encryptedData)); Console.WriteLine("解密后的数据: {0}", Encoding.UTF8.GetString(decryptedData)); } catch (CryptographicException e) { Console.WriteLine(e.Message); } } } // 使用RSA算法加密数据 public static byte[] EncryptData(byte[] dataToEncrypt, RSAParameters publicKey) { using (RSA rsa = RSA.Create()) { try { rsa.ImportParameters(publicKey); return rsa.Encrypt(dataToEncrypt, RSAEncryptionPadding.OaepSHA256); } catch (CryptographicException e) { Console.WriteLine(e.Message); return null; } } } // 使用RSA算法解密数据 public static byte[] DecryptData(byte[] dataToDecrypt, RSAParameters privateKey) { using (RSA rsa = RSA.Create()) { try { rsa.ImportParameters(privateKey); return rsa.Decrypt(dataToDecrypt, RSAEncryptionPadding.OaepSHA256); } catch (CryptographicException e) { Console.WriteLine(e.Message); return null; } } } } ``` 这个示例代码中,我们使用`RSA.Create()`创建了一个RSA实例,并设置了密钥长度为2048位。然后,调用`ExportParameters()`方法生成公钥和私钥对。接下来,我们使用公钥加密数据,然后再用私钥解密数据。最后,我们将结果打印到控制台上。 需要注意的是,RSA算法对于较大的数据加密耗时较长,因此通常会使用RSA算法加密对称加密算法(如AES)的密钥,从而提高加密效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值