/Recruitment/Common/EnCode.cs

http://fjaspx.codeplex.com · C# · 82 lines · 56 code · 3 blank · 23 comment · 1 complexity · 8cdee29b57eb038480d4deeaecda0d86 MD5 · raw file

  1. using System;
  2. using System.Data;
  3. using System.Configuration;
  4. using System.Web;
  5. using System.Web.Security;
  6. using System.Web.UI;
  7. using System.Web.UI.WebControls;
  8. using System.Web.UI.WebControls.WebParts;
  9. using System.Web.UI.HtmlControls;
  10. using System.Security.Cryptography;
  11. using System.Text;
  12. using System.IO;
  13. namespace Common
  14. {
  15. /// <summary>
  16. /// 加密解密类
  17. /// </summary>
  18. public class EnCode
  19. {
  20. public EnCode()
  21. {
  22. //
  23. // TODO: 在此处添加构造函数逻辑
  24. //
  25. }
  26. /// <summary>
  27. /// 加密。注意:sKey输入密码的时候,必须使用英文字符,区分大小写,且字符数量是8个,不能多也不能少,否则出错。
  28. /// </summary>
  29. /// <param name="pToEncrypt"></param>
  30. /// <param name="sKey"></param>
  31. /// <returns></returns>
  32. public static string Encrypt(string pToEncrypt, string sKey)
  33. {
  34. DESCryptoServiceProvider des = new DESCryptoServiceProvider();
  35. //把字符串放到byte数组中
  36. byte[] inputBytArray = Encoding.Default.GetBytes(pToEncrypt);
  37. //建立加密对象的密钥和偏移量
  38. //原文使用ASCIIEncoding.ASCII方法的GetBytes方法
  39. //使得输入密码必须输入英文文本
  40. des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
  41. des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
  42. MemoryStream ms = new MemoryStream();
  43. CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
  44. cs.Write(inputBytArray, 0, inputBytArray.Length);
  45. cs.FlushFinalBlock();
  46. StringBuilder ret = new StringBuilder();
  47. foreach (byte b in ms.ToArray())
  48. {
  49. ret.AppendFormat("{0:X2}", b);
  50. }
  51. return ret.ToString();
  52. }
  53. /// <summary>
  54. /// 解密
  55. /// </summary>
  56. /// <param name="pToDecrypt"></param>
  57. /// <param name="sKey"></param>
  58. /// <returns></returns>
  59. public static string DEcrypt(string pToDecrypt, string sKey)
  60. {
  61. DESCryptoServiceProvider des = new DESCryptoServiceProvider();
  62. byte[] inputByteArray = new byte[pToDecrypt.Length / 2];
  63. for (int x = 0; x < pToDecrypt.Length / 2; x++)
  64. {
  65. int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));
  66. inputByteArray[x] = (byte)i;
  67. }
  68. //建立加密对象的密钥和偏移量,此值重要,不能修改
  69. des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
  70. des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
  71. MemoryStream ms = new MemoryStream();
  72. CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
  73. cs.Write(inputByteArray, 0, inputByteArray.Length);
  74. cs.FlushFinalBlock();
  75. StringBuilder ret = new StringBuilder();
  76. return System.Text.Encoding.Default.GetString(ms.ToArray());
  77. }
  78. }
  79. }