238 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			238 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | /******************************************************************************* | |||
|  |  * Copyright © 2016 HT.Cloud.Framework 版权所有 | |||
|  |  * Author: HT.Cloud | |||
|  |  * Description: WaterCloud快速开发平台 | |||
|  |  * Website: | |||
|  | *********************************************************************************/ | |||
|  | 
 | |||
|  | using System; | |||
|  | using System.Security.Cryptography; | |||
|  | using System.Text; | |||
|  | 
 | |||
|  | namespace HT.Cloud.Code | |||
|  | { | |||
|  | 	/// <summary> | |||
|  | 	/// DES加密、解密帮助类 | |||
|  | 	/// </summary> | |||
|  | 	public class DESEncrypt | |||
|  | 	{ | |||
|  | 		private static string DESKey = "WaterCloud_desencrypt_2019"; | |||
|  | 
 | |||
|  | 		#region ========加密======== | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		/// 加密 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="Text"></param> | |||
|  | 		/// <returns></returns> | |||
|  | 		public static string Encrypt(string Text) | |||
|  | 		{ | |||
|  | 			return Encrypt(Text, DESKey); | |||
|  | 		} | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		/// 加密数据,用Web.Security的Hash方式加密 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="Text"></param> | |||
|  | 		/// <param name="sKey"></param> | |||
|  | 		/// <returns></returns> | |||
|  | 		public static string Encrypt(string Text, string sKey) | |||
|  | 		{ | |||
|  | 			DES des = DES.Create(); | |||
|  | 			byte[] inputByteArray; | |||
|  | 			inputByteArray = Encoding.Default.GetBytes(Text); | |||
|  | 			des.Key = ASCIIEncoding.ASCII.GetBytes(DecryptMd5(sKey)); | |||
|  | 			des.IV = ASCIIEncoding.ASCII.GetBytes(DecryptMd5(sKey)); | |||
|  | 			System.IO.MemoryStream ms = new System.IO.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); | |||
|  | 			} | |||
|  | 			return ret.ToString(); | |||
|  | 		} | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		///  加密数据, 用Security.MD5而非Web.Security的Hash方式加密 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="Text"></param> | |||
|  | 		/// <returns></returns> | |||
|  | 		public static string Encrypt2(string Text) | |||
|  | 		{ | |||
|  | 			return Encrypt2(Text, DESKey); | |||
|  | 		} | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		/// 加密数据, 用Security.MD5而非Web.Security的Hash方式加密 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="Text"></param> | |||
|  | 		/// <param name="sKey"></param> | |||
|  | 		/// <returns></returns> | |||
|  | 		public static string Encrypt2(string Text, string sKey) | |||
|  | 		{ | |||
|  | 			DES des = DES.Create(); | |||
|  | 			byte[] inputByteArray; | |||
|  | 			inputByteArray = Encoding.Default.GetBytes(Text); | |||
|  | 			sKey = MD5(sKey).Substring(0, 8); | |||
|  | 			des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); | |||
|  | 			des.IV = ASCIIEncoding.ASCII.GetBytes(sKey); | |||
|  | 			System.IO.MemoryStream ms = new System.IO.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); | |||
|  | 			} | |||
|  | 			return ret.ToString(); | |||
|  | 		} | |||
|  | 
 | |||
|  | 		#endregion ========加密======== | |||
|  | 
 | |||
|  | 		#region ========解密======== | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		/// 解密 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="Text"></param> | |||
|  | 		/// <returns></returns> | |||
|  | 		public static string Decrypt(string Text) | |||
|  | 		{ | |||
|  | 			if (!string.IsNullOrEmpty(Text)) | |||
|  | 			{ | |||
|  | 				return Decrypt(Text, DESKey); | |||
|  | 			} | |||
|  | 			else | |||
|  | 			{ | |||
|  | 				return ""; | |||
|  | 			} | |||
|  | 		} | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		/// 解密数据,用Web.Security的Hash方式加密 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="Text"></param> | |||
|  | 		/// <param name="sKey"></param> | |||
|  | 		/// <returns></returns> | |||
|  | 		public static string Decrypt(string Text, string sKey) | |||
|  | 		{ | |||
|  | 			DES des = DES.Create(); | |||
|  | 			int len; | |||
|  | 			len = Text.Length / 2; | |||
|  | 			byte[] inputByteArray = new byte[len]; | |||
|  | 			int x, i; | |||
|  | 			for (x = 0; x < len; x++) | |||
|  | 			{ | |||
|  | 				i = Convert.ToInt32(Text.Substring(x * 2, 2), 16); | |||
|  | 				inputByteArray[x] = (byte)i; | |||
|  | 			} | |||
|  | 
 | |||
|  | 			des.Key = ASCIIEncoding.ASCII.GetBytes(DecryptMd5(sKey)); | |||
|  | 			des.IV = ASCIIEncoding.ASCII.GetBytes(DecryptMd5(sKey)); | |||
|  | 			System.IO.MemoryStream ms = new System.IO.MemoryStream(); | |||
|  | 			CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write); | |||
|  | 			cs.Write(inputByteArray, 0, inputByteArray.Length); | |||
|  | 			cs.FlushFinalBlock(); | |||
|  | 			return Encoding.Default.GetString(ms.ToArray()); | |||
|  | 		} | |||
|  | 
 | |||
|  | 		public static string DecryptMd5(string str) | |||
|  | 		{ | |||
|  | 			string strEncrypt = string.Empty; | |||
|  | 			var md5 = System.Security.Cryptography.MD5.Create(); | |||
|  | 			var data = md5.ComputeHash(Encoding.UTF8.GetBytes(str)); | |||
|  | 			StringBuilder builder = new StringBuilder(); | |||
|  | 			// 循环遍历哈希数据的每一个字节并格式化为十六进制字符串 | |||
|  | 			for (int i = 0; i < data.Length; i++) | |||
|  | 			{ | |||
|  | 				builder.Append(data[i].ToString("X2")); | |||
|  | 			} | |||
|  | 			strEncrypt = builder.ToString().Substring(0, 8); | |||
|  | 			return strEncrypt; | |||
|  | 		} | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		/// 解密数据,用Security.MD5而非Web.Security的Hash方式加密 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="Text"></param> | |||
|  | 		/// <returns></returns> | |||
|  | 		public static string Decrypt2(string Text) | |||
|  | 		{ | |||
|  | 			if (!string.IsNullOrEmpty(Text)) | |||
|  | 			{ | |||
|  | 				return Decrypt2(Text, DESKey); | |||
|  | 			} | |||
|  | 			else | |||
|  | 			{ | |||
|  | 				return ""; | |||
|  | 			} | |||
|  | 		} | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		/// 解密数据,用Security.MD5而非Web.Security的Hash方式加密 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="Text"></param> | |||
|  | 		/// <param name="sKey"></param> | |||
|  | 		/// <returns></returns> | |||
|  | 		public static string Decrypt2(string Text, string sKey) | |||
|  | 		{ | |||
|  | 			DES des = DES.Create(); | |||
|  | 			int len; | |||
|  | 			len = Text.Length / 2; | |||
|  | 			byte[] inputByteArray = new byte[len]; | |||
|  | 			int x, i; | |||
|  | 			for (x = 0; x < len; x++) | |||
|  | 			{ | |||
|  | 				i = Convert.ToInt32(Text.Substring(x * 2, 2), 16); | |||
|  | 				inputByteArray[x] = (byte)i; | |||
|  | 			} | |||
|  | 			sKey = MD5(sKey).Substring(0, 8); | |||
|  | 			des.Key = ASCIIEncoding.ASCII.GetBytes(sKey); | |||
|  | 			des.IV = ASCIIEncoding.ASCII.GetBytes(sKey); | |||
|  | 			System.IO.MemoryStream ms = new System.IO.MemoryStream(); | |||
|  | 			CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write); | |||
|  | 			cs.Write(inputByteArray, 0, inputByteArray.Length); | |||
|  | 			cs.FlushFinalBlock(); | |||
|  | 			return Encoding.Default.GetString(ms.ToArray()); | |||
|  | 		} | |||
|  | 
 | |||
|  | 		#endregion ========解密======== | |||
|  | 
 | |||
|  | 		public static string MD5(string pwd) | |||
|  | 		{ | |||
|  | 			MD5 md5 = System.Security.Cryptography.MD5.Create(); | |||
|  | 			byte[] data = System.Text.Encoding.Default.GetBytes(pwd); | |||
|  | 			byte[] md5data = md5.ComputeHash(data); | |||
|  | 			md5.Clear(); | |||
|  | 			string str = ""; | |||
|  | 			for (int i = 0; i < md5data.Length; i++) | |||
|  | 			{ | |||
|  | 				str += md5data[i].ToString("x").PadLeft(2, '0'); | |||
|  | 			} | |||
|  | 			return str; | |||
|  | 		} | |||
|  | 
 | |||
|  | 		/// <summary> | |||
|  | 		/// 基于Sha1的自定义加密字符串方法:输入一个字符串,返回一个由40个字符组成的十六进制的哈希散列(字符串)。 | |||
|  | 		/// </summary> | |||
|  | 		/// <param name="str">要加密的字符串</param> | |||
|  | 		/// <returns>加密后的十六进制的哈希散列(字符串)</returns> | |||
|  | 		public static string Sha1(string str) | |||
|  | 		{ | |||
|  | 			var buffer = Encoding.UTF8.GetBytes(str); | |||
|  | 			var data = SHA1.Create().ComputeHash(buffer); | |||
|  | 
 | |||
|  | 			var sb = new StringBuilder(); | |||
|  | 			foreach (var t in data) | |||
|  | 			{ | |||
|  | 				sb.Append(t.ToString("X2")); | |||
|  | 			} | |||
|  | 
 | |||
|  | 			return sb.ToString(); | |||
|  | 		} | |||
|  | 	} | |||
|  | } |