/infrastructure/iPow.Infrastructure.Crosscutting.Function/EncryptionHelper.cs
https://bitbucket.org/JPomichael/miaow · C# · 84 lines · 53 code · 9 blank · 22 comment · 1 complexity · 16f149e44217dcc191a57195d17d4bbf MD5 · raw file
- using System;
- using System.Collections.Generic;
- using System.Text;
- using System.Security.Cryptography;
- using System.Web;
- using System.IO;
- namespace iPow.Infrastructure.Crosscutting.Function
- {
- /// <summary>
- /// DESEnCode DES密码工具集
- /// Copyright (C) 2008-2010 深圳互动力科技有限公司
- /// All rights reserved
- /// </summary>
- public class EncryptionHelper
- {
- #region DESEnCode DES加密
- /// <summary>
- /// DES加密函数
- /// </summary>
- /// <param name="pToEncrypt">要加密的字符串</param>
- /// <param name="sKey">加密密钥</param>
- /// <returns>返回加密字符串</returns>
- public static string DESEnCode(string pToEncrypt, string sKey)
- {
- pToEncrypt = HttpContext.Current.Server.UrlEncode(pToEncrypt);
- DESCryptoServiceProvider des = new DESCryptoServiceProvider();
- byte[] inputByteArray = Encoding.GetEncoding("UTF-8").GetBytes(pToEncrypt);
- //建立加密对象的密钥和偏移量
- //原文使用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);
- cs.Write(inputByteArray, 0, inputByteArray.Length);
- cs.FlushFinalBlock();
- StringBuilder ret = new StringBuilder();
- foreach (byte b in ms.ToArray())
- {
- ret.AppendFormat("{0:X2}", b);
- }
- ret.ToString();
- return ret.ToString();
- }
- #endregion
- #region DESDeCode DES解密
- /// <summary>
- /// DES解密函数
- /// </summary>
- /// <param name="pToDecrypt">需要被解密的字符串</param>
- /// <param name="sKey">解密密钥</param>
- /// <returns>返回解密字符串</returns>
- public static string DESDeCode(string pToDecrypt, string sKey)
- {
- // HttpContext.Current.Response.Write(pToDecrypt + "<br>" + sKey);
- // HttpContext.Current.Response.End();
- DESCryptoServiceProvider des = new DESCryptoServiceProvider();
- 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;
- }
- 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);
- cs.Write(inputByteArray, 0, inputByteArray.Length);
- cs.FlushFinalBlock();
- StringBuilder ret = new StringBuilder();
- return HttpContext.Current.Server.UrlDecode(System.Text.Encoding.Default.GetString(ms.ToArray()));
- }
- #endregion
- }
- }