DES加密解密

一直觉得协同对接只靠一个穿参数,是很脆弱和不安全的,可目前短时间内还是没有其他好的办法,于是决定以后的程序对接都应该至少把参数进行一次加密,于是就研究了一下,终于可以用了,可是对原理还是很清楚,有待于提高,明天在家复习,后天去曲阳拿代码,大后天凉城部署,星期四最后一门考试,忙!时间不够用啊!

//解密函数
  public static string DesDecrypt(string strText,string sDecrKey)
  {
   byte[] byKey = null;
   byte[] IV= {0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF};
   byte[] inputByteArray = new Byte[strText.Length];
   byKey = System.Text.Encoding.UTF8.GetBytes(sDecrKey.Substring(0,8));
   DESCryptoServiceProvider des = new DESCryptoServiceProvider();
   inputByteArray = Convert.FromBase64String(strText);
   MemoryStream ms = new MemoryStream();
   CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(byKey, IV), CryptoStreamMode.Write);
   cs.Write(inputByteArray, 0, inputByteArray.Length);
   cs.FlushFinalBlock();
   System.Text.Encoding encoding = new System.Text.UTF8Encoding();
   return encoding.GetString(ms.ToArray());
  }

  //加密函数
  public static string DesEncrypt(string strText, string strEncrKey)
  {
   byte[] byKey=null;
   byte[] IV= {0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF};
   byKey = System.Text.Encoding.UTF8.GetBytes(strEncrKey.Substring(0,8));
   DESCryptoServiceProvider des = new DESCryptoServiceProvider();
   byte[] inputByteArray = Encoding.UTF8.GetBytes(strText);
   MemoryStream ms = new MemoryStream();
   CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(byKey, IV), CryptoStreamMode.Write);
   cs.Write(inputByteArray, 0, inputByteArray.Length);
   cs.FlushFinalBlock();
   return Convert.ToBase64String(ms.ToArray());
  }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值