Encrypt.cs 50 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297
  1. using System;
  2. using System.IO;
  3. using System.Linq;
  4. using System.Security.Cryptography;
  5. using System.Text;
  6. using System.Text.RegularExpressions;
  7. namespace Masuit.Tools.Security
  8. {
  9. /// <summary>
  10. /// 常用的加密解密算法
  11. /// </summary>
  12. public static class Encrypt
  13. {
  14. #region DES对称加密解密
  15. /// <summary>
  16. /// 加密密钥,默认取“masuit”的MD5值
  17. /// </summary>
  18. public static string DefaultEncryptKey = "masuit".MDString2();
  19. /// <summary>
  20. /// 使用默认加密
  21. /// </summary>
  22. /// <param name="strText">被加密的字符串</param>
  23. /// <returns>加密后的数据</returns>
  24. public static string DesEncrypt(this string strText)
  25. {
  26. try
  27. {
  28. return DesEncrypt(strText, DefaultEncryptKey);
  29. }
  30. catch
  31. {
  32. return "";
  33. }
  34. }
  35. /// <summary>
  36. /// 使用默认解密
  37. /// </summary>
  38. /// <param name="strText">需要解密的 字符串</param>
  39. /// <returns>解密后的数据</returns>
  40. public static string DesDecrypt(this string strText)
  41. {
  42. try
  43. {
  44. return DesDecrypt(strText, DefaultEncryptKey);
  45. }
  46. catch
  47. {
  48. return "";
  49. }
  50. }
  51. /// <summary>
  52. /// 加密字符串
  53. /// 加密密钥必须为8位
  54. /// </summary>
  55. /// <param name="strText">被加密的字符串</param>
  56. /// <param name="strEncrKey">8位长度密钥</param>
  57. /// <returns>加密后的数据</returns>
  58. public static string DesEncrypt(this string strText, string strEncrKey)
  59. {
  60. if (strEncrKey.Length < 8)
  61. {
  62. throw new Exception("密钥长度无效,密钥必须是8位!");
  63. }
  64. StringBuilder ret = new StringBuilder();
  65. using var des = new DESCryptoServiceProvider();
  66. byte[] inputByteArray = Encoding.Default.GetBytes(strText);
  67. des.Key = Encoding.ASCII.GetBytes(strEncrKey.Substring(0, 8));
  68. des.IV = Encoding.ASCII.GetBytes(strEncrKey.Substring(0, 8));
  69. MemoryStream ms = new MemoryStream();
  70. using var cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
  71. cs.Write(inputByteArray, 0, inputByteArray.Length);
  72. cs.FlushFinalBlock();
  73. foreach (byte b in ms.ToArray())
  74. {
  75. ret.AppendFormat($"{b:X2}");
  76. }
  77. return ret.ToString();
  78. }
  79. /// <summary>
  80. /// 加密字符串
  81. /// 加密密钥必须为8位
  82. /// </summary>
  83. /// <param name="strText">被加密的字符串</param>
  84. /// <param name="desKey"></param>
  85. /// <param name="desIV"></param>
  86. /// <returns>加密后的数据</returns>
  87. public static string DesEncrypt(this string strText, byte[] desKey, byte[] desIV)
  88. {
  89. StringBuilder ret = new StringBuilder();
  90. using var des = new DESCryptoServiceProvider();
  91. byte[] inputByteArray = Encoding.Default.GetBytes(strText);
  92. des.Key = desKey;
  93. des.IV = desIV;
  94. MemoryStream ms = new MemoryStream();
  95. using var cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
  96. cs.Write(inputByteArray, 0, inputByteArray.Length);
  97. cs.FlushFinalBlock();
  98. foreach (byte b in ms.ToArray())
  99. {
  100. ret.AppendFormat($"{b:X2}");
  101. }
  102. return ret.ToString();
  103. }
  104. /// <summary>
  105. /// DES加密文件
  106. /// </summary>
  107. /// <param name="fin">文件输入流</param>
  108. /// <param name="outFilePath">文件输出路径</param>
  109. /// <param name="strEncrKey">加密密钥</param>
  110. public static void DesEncrypt(this FileStream fin, string outFilePath, string strEncrKey)
  111. {
  112. byte[] iv =
  113. {
  114. 0x12,
  115. 0x34,
  116. 0x56,
  117. 0x78,
  118. 0x90,
  119. 0xAB,
  120. 0xCD,
  121. 0xEF
  122. };
  123. var byKey = Encoding.UTF8.GetBytes(strEncrKey.Substring(0, 8));
  124. using var fout = new FileStream(outFilePath, FileMode.OpenOrCreate, FileAccess.Write);
  125. fout.SetLength(0);
  126. byte[] bin = new byte[100];
  127. long rdlen = 0;
  128. long totlen = fin.Length;
  129. DES des = new DESCryptoServiceProvider();
  130. var encStream = new CryptoStream(fout, des.CreateEncryptor(byKey, iv), CryptoStreamMode.Write);
  131. while (rdlen < totlen)
  132. {
  133. var len = fin.Read(bin, 0, 100);
  134. encStream.Write(bin, 0, len);
  135. rdlen += len;
  136. }
  137. }
  138. /// <summary>
  139. /// DES加密文件
  140. /// </summary>
  141. /// <param name="fin">文件输入流</param>
  142. /// <param name="outFilePath">文件输出路径</param>
  143. /// <param name="desKey"></param>
  144. /// <param name="desIV"></param>
  145. public static void DesEncrypt(this FileStream fin, string outFilePath, byte[] desKey, byte[] desIV)
  146. {
  147. using var fout = new FileStream(outFilePath, FileMode.OpenOrCreate, FileAccess.Write);
  148. fout.SetLength(0);
  149. byte[] bin = new byte[100];
  150. long rdlen = 0;
  151. long totlen = fin.Length;
  152. DES des = new DESCryptoServiceProvider();
  153. var encStream = new CryptoStream(fout, des.CreateEncryptor(desKey, desIV), CryptoStreamMode.Write);
  154. while (rdlen < totlen)
  155. {
  156. var len = fin.Read(bin, 0, 100);
  157. encStream.Write(bin, 0, len);
  158. rdlen += len;
  159. }
  160. }
  161. /// <summary>
  162. /// DES解密文件
  163. /// </summary>
  164. /// <param name="fin">输入文件流</param>
  165. /// <param name="outFilePath">文件输出路径</param>
  166. /// <param name="sDecrKey">解密密钥</param>
  167. public static void DesDecrypt(this FileStream fin, string outFilePath, string sDecrKey)
  168. {
  169. byte[] iv =
  170. {
  171. 0x12,
  172. 0x34,
  173. 0x56,
  174. 0x78,
  175. 0x90,
  176. 0xAB,
  177. 0xCD,
  178. 0xEF
  179. };
  180. var byKey = Encoding.UTF8.GetBytes(sDecrKey.Substring(0, 8));
  181. using var fout = new FileStream(outFilePath, FileMode.OpenOrCreate, FileAccess.Write);
  182. fout.SetLength(0);
  183. byte[] bin = new byte[100];
  184. long rdlen = 0;
  185. long totlen = fin.Length;
  186. using DES des = new DESCryptoServiceProvider();
  187. var encStream = new CryptoStream(fout, des.CreateDecryptor(byKey, iv), CryptoStreamMode.Write);
  188. while (rdlen < totlen)
  189. {
  190. var len = fin.Read(bin, 0, 100);
  191. encStream.Write(bin, 0, len);
  192. rdlen += len;
  193. }
  194. }
  195. /// <summary>
  196. /// DES解密文件
  197. /// </summary>
  198. /// <param name="fin">输入文件流</param>
  199. /// <param name="outFilePath">文件输出路径</param>
  200. /// <param name="desKey"></param>
  201. /// <param name="desIV"></param>
  202. public static void DesDecrypt(this FileStream fin, string outFilePath, byte[] desKey, byte[] desIV)
  203. {
  204. using var fout = new FileStream(outFilePath, FileMode.OpenOrCreate, FileAccess.Write);
  205. fout.SetLength(0);
  206. byte[] bin = new byte[100];
  207. long rdlen = 0;
  208. long totlen = fin.Length;
  209. using DES des = new DESCryptoServiceProvider();
  210. var encStream = new CryptoStream(fout, des.CreateDecryptor(desKey, desIV), CryptoStreamMode.Write);
  211. while (rdlen < totlen)
  212. {
  213. var len = fin.Read(bin, 0, 100);
  214. encStream.Write(bin, 0, len);
  215. rdlen += len;
  216. }
  217. }
  218. /// <summary>
  219. /// DES解密算法
  220. /// 密钥为8位
  221. /// </summary>
  222. /// <param name="pToDecrypt">需要解密的字符串</param>
  223. /// <param name="sKey">密钥</param>
  224. /// <returns>解密后的数据</returns>
  225. public static string DesDecrypt(this string pToDecrypt, string sKey)
  226. {
  227. if (sKey.Length < 8)
  228. {
  229. throw new Exception("密钥长度无效,密钥必须是8位!");
  230. }
  231. var ms = new MemoryStream();
  232. using var des = new DESCryptoServiceProvider();
  233. var inputByteArray = new byte[pToDecrypt.Length / 2];
  234. for (int x = 0; x < pToDecrypt.Length / 2; x++)
  235. {
  236. int i = Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16);
  237. inputByteArray[x] = (byte)i;
  238. }
  239. des.Key = Encoding.ASCII.GetBytes(sKey.Substring(0, 8));
  240. des.IV = Encoding.ASCII.GetBytes(sKey.Substring(0, 8));
  241. using var cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
  242. cs.Write(inputByteArray, 0, inputByteArray.Length);
  243. cs.FlushFinalBlock();
  244. return Encoding.Default.GetString(ms.ToArray());
  245. }
  246. /// <summary>
  247. /// DES解密算法
  248. /// 密钥为8位
  249. /// </summary>
  250. /// <param name="pToDecrypt">需要解密的字符串</param>
  251. /// <param name="desKey"></param>
  252. /// <param name="desIV"></param>
  253. /// <returns>解密后的数据</returns>
  254. public static string DesDecrypt(this string pToDecrypt, byte[] desKey, byte[] desIV)
  255. {
  256. var ms = new MemoryStream();
  257. using var des = new DESCryptoServiceProvider();
  258. var inputByteArray = new byte[pToDecrypt.Length / 2];
  259. for (int x = 0; x < pToDecrypt.Length / 2; x++)
  260. {
  261. int i = Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16);
  262. inputByteArray[x] = (byte)i;
  263. }
  264. des.Key = desKey;
  265. des.IV = desIV;
  266. using var cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
  267. cs.Write(inputByteArray, 0, inputByteArray.Length);
  268. cs.FlushFinalBlock();
  269. return Encoding.Default.GetString(ms.ToArray());
  270. }
  271. #endregion
  272. #region 对称加密算法AES RijndaelManaged加密解密
  273. private static readonly string Default_AES_Key = "@#kim123";
  274. private static byte[] Keys =
  275. {
  276. 0x41,
  277. 0x72,
  278. 0x65,
  279. 0x79,
  280. 0x6F,
  281. 0x75,
  282. 0x6D,
  283. 0x79,
  284. 0x53,
  285. 0x6E,
  286. 0x6F,
  287. 0x77,
  288. 0x6D,
  289. 0x61,
  290. 0x6E,
  291. 0x3F
  292. };
  293. /// <summary>
  294. /// 生成符合AES加密规则的密钥
  295. /// </summary>
  296. /// <param name="length"></param>
  297. /// <returns></returns>
  298. public static string GenerateAesKey(int length)
  299. {
  300. var crypto = new AesCryptoServiceProvider
  301. {
  302. KeySize = length,
  303. BlockSize = 128
  304. };
  305. crypto.GenerateKey();
  306. return Convert.ToBase64String(crypto.Key);
  307. }
  308. /// <summary>
  309. /// 对称加密算法AES RijndaelManaged加密(RijndaelManaged(AES)算法是块式加密算法)
  310. /// </summary>
  311. /// <param name="encryptString">待加密字符串</param>
  312. /// <returns>加密结果字符串</returns>
  313. public static string AESEncrypt(this string encryptString)
  314. {
  315. return AESEncrypt(encryptString, Default_AES_Key);
  316. }
  317. /// <summary>
  318. /// 对称加密算法AES RijndaelManaged加密(RijndaelManaged(AES)算法是块式加密算法)
  319. /// </summary>
  320. /// <param name="encryptString">待加密字符串</param>
  321. /// <param name="encryptKey">加密密钥,须半角字符</param>
  322. /// <returns>加密结果字符串</returns>
  323. public static string AESEncrypt(this string encryptString, string encryptKey)
  324. {
  325. encryptKey = GetSubString(encryptKey, 32, "");
  326. encryptKey = encryptKey.PadRight(32, ' ');
  327. using var rijndaelProvider = new RijndaelManaged
  328. {
  329. Key = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 32)),
  330. IV = Keys
  331. };
  332. using ICryptoTransform rijndaelEncrypt = rijndaelProvider.CreateEncryptor();
  333. byte[] inputData = Encoding.UTF8.GetBytes(encryptString);
  334. byte[] encryptedData = rijndaelEncrypt.TransformFinalBlock(inputData, 0, inputData.Length);
  335. return Convert.ToBase64String(encryptedData);
  336. }
  337. /// <summary>
  338. /// 对称加密算法AES RijndaelManaged加密(RijndaelManaged(AES)算法是块式加密算法)
  339. /// </summary>
  340. /// <param name="encryptString">待加密字符串</param>
  341. /// <param name="encryptKey">加密密钥,须半角字符</param>
  342. /// <returns>加密结果字符串</returns>
  343. public static string AESEncrypt(this string encryptString, byte[] encryptKey)
  344. {
  345. using var rijndaelProvider = new RijndaelManaged
  346. {
  347. Key = encryptKey,
  348. IV = Keys
  349. };
  350. using ICryptoTransform rijndaelEncrypt = rijndaelProvider.CreateEncryptor();
  351. byte[] inputData = Encoding.UTF8.GetBytes(encryptString);
  352. byte[] encryptedData = rijndaelEncrypt.TransformFinalBlock(inputData, 0, inputData.Length);
  353. return Convert.ToBase64String(encryptedData);
  354. }
  355. /// <summary>
  356. /// 对称加密算法AES RijndaelManaged解密字符串
  357. /// </summary>
  358. /// <param name="decryptString">待解密的字符串</param>
  359. /// <returns>解密成功返回解密后的字符串,失败返源串</returns>
  360. public static string AESDecrypt(this string decryptString)
  361. {
  362. return AESDecrypt(decryptString, Default_AES_Key);
  363. }
  364. /// <summary>
  365. /// 对称加密算法AES RijndaelManaged解密字符串
  366. /// </summary>
  367. /// <param name="decryptString">待解密的字符串</param>
  368. /// <param name="decryptKey">解密密钥,和加密密钥相同</param>
  369. /// <returns>解密成功返回解密后的字符串,失败返回空</returns>
  370. public static string AESDecrypt(this string decryptString, string decryptKey)
  371. {
  372. try
  373. {
  374. decryptKey = GetSubString(decryptKey, 32, "");
  375. decryptKey = decryptKey.PadRight(32, ' ');
  376. using var rijndaelProvider = new RijndaelManaged()
  377. {
  378. Key = Encoding.UTF8.GetBytes(decryptKey),
  379. IV = Keys
  380. };
  381. using ICryptoTransform rijndaelDecrypt = rijndaelProvider.CreateDecryptor();
  382. byte[] inputData = Convert.FromBase64String(decryptString);
  383. byte[] decryptedData = rijndaelDecrypt.TransformFinalBlock(inputData, 0, inputData.Length);
  384. return Encoding.UTF8.GetString(decryptedData);
  385. }
  386. catch
  387. {
  388. return string.Empty;
  389. }
  390. }
  391. /// <summary>
  392. /// 对称加密算法AES RijndaelManaged解密字符串
  393. /// </summary>
  394. /// <param name="decryptString">待解密的字符串</param>
  395. /// <param name="decryptKey">解密密钥,和加密密钥相同</param>
  396. /// <returns>解密成功返回解密后的字符串,失败返回空</returns>
  397. public static string AESDecrypt(this string decryptString, byte[] decryptKey)
  398. {
  399. try
  400. {
  401. using var rijndaelProvider = new RijndaelManaged()
  402. {
  403. Key = decryptKey,
  404. IV = Keys
  405. };
  406. using ICryptoTransform rijndaelDecrypt = rijndaelProvider.CreateDecryptor();
  407. byte[] inputData = Convert.FromBase64String(decryptString);
  408. byte[] decryptedData = rijndaelDecrypt.TransformFinalBlock(inputData, 0, inputData.Length);
  409. return Encoding.UTF8.GetString(decryptedData);
  410. }
  411. catch
  412. {
  413. return string.Empty;
  414. }
  415. }
  416. /// <summary>
  417. /// 按字节长度(按字节,一个汉字为2个字节)取得某字符串的一部分
  418. /// </summary>
  419. /// <param name="sourceString">源字符串</param>
  420. /// <param name="length">所取字符串字节长度</param>
  421. /// <param name="tailString">附加字符串(当字符串不够长时,尾部所添加的字符串,一般为"...")</param>
  422. /// <returns>某字符串的一部分</returns>
  423. private static string GetSubString(this string sourceString, int length, string tailString)
  424. {
  425. return GetSubString(sourceString, 0, length, tailString);
  426. }
  427. /// <summary>
  428. /// 按字节长度(按字节,一个汉字为2个字节)取得某字符串的一部分
  429. /// </summary>
  430. /// <param name="sourceString">源字符串</param>
  431. /// <param name="startIndex">索引位置,以0开始</param>
  432. /// <param name="length">所取字符串字节长度</param>
  433. /// <param name="tailString">附加字符串(当字符串不够长时,尾部所添加的字符串,一般为"...")</param>
  434. /// <returns>某字符串的一部分</returns>
  435. private static string GetSubString(this string sourceString, int startIndex, int length, string tailString)
  436. {
  437. //当是日文或韩文时(注:中文的范围:\u4e00 - \u9fa5, 日文在\u0800 - \u4e00, 韩文为\xAC00-\xD7A3)
  438. if (Regex.IsMatch(sourceString, "[\u0800-\u4e00]+") || Regex.IsMatch(sourceString, "[\xAC00-\xD7A3]+"))
  439. {
  440. //当截取的起始位置超出字段串长度时
  441. if (startIndex >= sourceString.Length)
  442. {
  443. return string.Empty;
  444. }
  445. return sourceString.Substring(startIndex, length + startIndex > sourceString.Length ? (sourceString.Length - startIndex) : length);
  446. }
  447. //中文字符,如"中国人民abcd123"
  448. if (length <= 0)
  449. {
  450. return string.Empty;
  451. }
  452. byte[] bytesSource = Encoding.Default.GetBytes(sourceString);
  453. //当字符串长度大于起始位置
  454. if (bytesSource.Length > startIndex)
  455. {
  456. int endIndex = bytesSource.Length;
  457. //当要截取的长度在字符串的有效长度范围内
  458. if (bytesSource.Length > (startIndex + length))
  459. {
  460. endIndex = length + startIndex;
  461. }
  462. else
  463. {
  464. //当不在有效范围内时,只取到字符串的结尾
  465. length = bytesSource.Length - startIndex;
  466. tailString = "";
  467. }
  468. var anResultFlag = new int[length];
  469. int nFlag = 0;
  470. //字节大于127为双字节字符
  471. for (int i = startIndex; i < endIndex; i++)
  472. {
  473. if (bytesSource[i] > 127)
  474. {
  475. nFlag++;
  476. if (nFlag == 3)
  477. {
  478. nFlag = 1;
  479. }
  480. }
  481. else
  482. {
  483. nFlag = 0;
  484. }
  485. anResultFlag[i] = nFlag;
  486. }
  487. //最后一个字节为双字节字符的一半
  488. if ((bytesSource[endIndex - 1] > 127) && (anResultFlag[length - 1] == 1))
  489. {
  490. length++;
  491. }
  492. byte[] bsResult = new byte[length];
  493. Array.Copy(bytesSource, startIndex, bsResult, 0, length);
  494. var myResult = Encoding.Default.GetString(bsResult);
  495. myResult += tailString;
  496. return myResult;
  497. }
  498. return string.Empty;
  499. }
  500. /// <summary>
  501. /// 加密文件流
  502. /// </summary>
  503. /// <param name="fs">需要加密的文件流</param>
  504. /// <param name="decryptKey">加密密钥</param>
  505. /// <returns>加密流</returns>
  506. public static CryptoStream AESEncryptStrream(this FileStream fs, string decryptKey)
  507. {
  508. decryptKey = GetSubString(decryptKey, 32, "");
  509. decryptKey = decryptKey.PadRight(32, ' ');
  510. using var rijndaelProvider = new RijndaelManaged()
  511. {
  512. Key = Encoding.UTF8.GetBytes(decryptKey),
  513. IV = Keys
  514. };
  515. using var encrypto = rijndaelProvider.CreateEncryptor();
  516. return new CryptoStream(fs, encrypto, CryptoStreamMode.Write);
  517. }
  518. /// <summary>
  519. /// 加密文件流
  520. /// </summary>
  521. /// <param name="fs">需要加密的文件流</param>
  522. /// <param name="decryptKey">加密密钥</param>
  523. /// <returns>加密流</returns>
  524. public static CryptoStream AESEncryptStrream(this FileStream fs, byte[] decryptKey)
  525. {
  526. using var rijndaelProvider = new RijndaelManaged()
  527. {
  528. Key = decryptKey,
  529. IV = Keys
  530. };
  531. using var encrypto = rijndaelProvider.CreateEncryptor();
  532. return new CryptoStream(fs, encrypto, CryptoStreamMode.Write);
  533. }
  534. /// <summary>
  535. /// 解密文件流
  536. /// </summary>
  537. /// <param name="fs">需要解密的文件流</param>
  538. /// <param name="decryptKey">解密密钥</param>
  539. /// <returns>加密流</returns>
  540. public static CryptoStream AESDecryptStream(this FileStream fs, string decryptKey)
  541. {
  542. decryptKey = GetSubString(decryptKey, 32, "");
  543. decryptKey = decryptKey.PadRight(32, ' ');
  544. using var rijndaelProvider = new RijndaelManaged()
  545. {
  546. Key = Encoding.UTF8.GetBytes(decryptKey),
  547. IV = Keys
  548. };
  549. using var decrypto = rijndaelProvider.CreateDecryptor();
  550. return new CryptoStream(fs, decrypto, CryptoStreamMode.Read);
  551. }
  552. /// <summary>
  553. /// 解密文件流
  554. /// </summary>
  555. /// <param name="fs">需要解密的文件流</param>
  556. /// <param name="decryptKey">解密密钥</param>
  557. /// <returns>加密流</returns>
  558. public static CryptoStream AESDecryptStream(this FileStream fs, byte[] decryptKey)
  559. {
  560. using var rijndaelProvider = new RijndaelManaged()
  561. {
  562. Key = decryptKey,
  563. IV = Keys
  564. };
  565. using var decrypto = rijndaelProvider.CreateDecryptor();
  566. return new CryptoStream(fs, decrypto, CryptoStreamMode.Read);
  567. }
  568. /// <summary>
  569. /// 对指定文件AES加密
  570. /// </summary>
  571. /// <param name="input">源文件流</param>
  572. /// <param name="outputPath">输出文件路径</param>
  573. public static void AESEncryptFile(this FileStream input, string outputPath)
  574. {
  575. using var fren = new FileStream(outputPath, FileMode.Create);
  576. using var enfr = AESEncryptStrream(fren, Default_AES_Key);
  577. byte[] bytearrayinput = new byte[input.Length];
  578. input.Read(bytearrayinput, 0, bytearrayinput.Length);
  579. enfr.Write(bytearrayinput, 0, bytearrayinput.Length);
  580. }
  581. /// <summary>
  582. /// 对指定的文件AES解密
  583. /// </summary>
  584. /// <param name="input">源文件流</param>
  585. /// <param name="outputPath">输出文件路径</param>
  586. public static void AESDecryptFile(this FileStream input, string outputPath)
  587. {
  588. using FileStream frde = new FileStream(outputPath, FileMode.Create);
  589. using CryptoStream defr = AESDecryptStream(input, Default_AES_Key);
  590. byte[] bytearrayoutput = new byte[1024];
  591. while (true)
  592. {
  593. var count = defr.Read(bytearrayoutput, 0, bytearrayoutput.Length);
  594. frde.Write(bytearrayoutput, 0, count);
  595. if (count < bytearrayoutput.Length)
  596. {
  597. break;
  598. }
  599. }
  600. }
  601. #endregion
  602. #region Base64加密解密
  603. /// <summary>
  604. /// Base64加密
  605. /// </summary>
  606. /// <param name="str">需要加密的字符串</param>
  607. /// <returns>加密后的数据</returns>
  608. public static string Base64Encrypt(this string str)
  609. {
  610. byte[] encbuff = Encoding.UTF8.GetBytes(str);
  611. return Convert.ToBase64String(encbuff);
  612. }
  613. /// <summary>
  614. /// Base64解密
  615. /// </summary>
  616. /// <param name="str">需要解密的字符串</param>
  617. /// <returns>解密后的数据</returns>
  618. public static string Base64Decrypt(this string str)
  619. {
  620. byte[] decbuff = Convert.FromBase64String(str);
  621. return Encoding.UTF8.GetString(decbuff);
  622. }
  623. #endregion
  624. /// <summary>
  625. /// SHA256函数
  626. /// </summary>
  627. /// <param name="str">原始字符串</param>
  628. /// <returns>SHA256结果(返回长度为44字节的字符串)</returns>
  629. public static string SHA256(this string str)
  630. {
  631. byte[] sha256Data = Encoding.UTF8.GetBytes(str);
  632. using var sha256 = new SHA256Managed();
  633. byte[] result = sha256.ComputeHash(sha256Data);
  634. return Convert.ToBase64String(result); //返回长度为44字节的字符串
  635. }
  636. #region MD5加密算法
  637. #region 对字符串进行MD5加密
  638. /// <summary>
  639. /// 对字符串进行MD5加密
  640. /// </summary>
  641. /// <param name="message">需要加密的字符串</param>
  642. /// <returns>加密后的结果</returns>
  643. public static string MDString(this string message)
  644. {
  645. MD5 md5 = MD5.Create();
  646. byte[] buffer = Encoding.Default.GetBytes(message);
  647. byte[] bytes = md5.ComputeHash(buffer);
  648. return bytes.Aggregate("", (current, b) => current + b.ToString("x2"));
  649. }
  650. /// <summary>
  651. /// 对字符串进行MD5二次加密
  652. /// </summary>
  653. /// <param name="message">需要加密的字符串</param>
  654. /// <returns>加密后的结果</returns>
  655. public static string MDString2(this string message) => MDString(MDString(message));
  656. /// <summary>
  657. /// MD5 三次加密算法
  658. /// </summary>
  659. /// <param name="s">需要加密的字符串</param>
  660. /// <returns>MD5字符串</returns>
  661. public static string MDString3(this string s)
  662. {
  663. using MD5 md5 = MD5.Create();
  664. byte[] bytes = Encoding.ASCII.GetBytes(s);
  665. byte[] bytes1 = md5.ComputeHash(bytes);
  666. byte[] bytes2 = md5.ComputeHash(bytes1);
  667. byte[] bytes3 = md5.ComputeHash(bytes2);
  668. return bytes3.Aggregate("", (current, b) => current + b.ToString("x2"));
  669. }
  670. /// <summary>
  671. /// 对字符串进行MD5加盐加密
  672. /// </summary>
  673. /// <param name="message">需要加密的字符串</param>
  674. /// <param name="salt">盐</param>
  675. /// <returns>加密后的结果</returns>
  676. public static string MDString(this string message, string salt) => MDString(message + salt);
  677. /// <summary>
  678. /// 对字符串进行MD5二次加盐加密
  679. /// </summary>
  680. /// <param name="message">需要加密的字符串</param>
  681. /// <param name="salt">盐</param>
  682. /// <returns>加密后的结果</returns>
  683. public static string MDString2(this string message, string salt) => MDString(MDString(message + salt), salt);
  684. /// <summary>
  685. /// MD5 三次加密算法
  686. /// </summary>
  687. /// <param name="s">需要加密的字符串</param>
  688. /// <param name="salt">盐</param>
  689. /// <returns>MD5字符串</returns>
  690. public static string MDString3(this string s, string salt)
  691. {
  692. using MD5 md5 = MD5.Create();
  693. byte[] bytes = Encoding.ASCII.GetBytes(s + salt);
  694. byte[] bytes1 = md5.ComputeHash(bytes);
  695. byte[] bytes2 = md5.ComputeHash(bytes1);
  696. byte[] bytes3 = md5.ComputeHash(bytes2);
  697. return bytes3.Aggregate("", (current, b) => current + b.ToString("x2"));
  698. }
  699. #endregion
  700. #region 获取文件的MD5值
  701. /// <summary>
  702. /// 获取文件的MD5值
  703. /// </summary>
  704. /// <param name="fileName">需要求MD5值的文件的文件名及路径</param>
  705. /// <returns>MD5字符串</returns>
  706. public static string MDFile(this string fileName)
  707. {
  708. using var fs = new BufferedStream(File.Open(fileName, FileMode.Open, FileAccess.Read), 1048576);
  709. using MD5 md5 = MD5.Create();
  710. byte[] bytes = md5.ComputeHash(fs);
  711. return bytes.Aggregate("", (current, b) => current + b.ToString("x2"));
  712. }
  713. /// <summary>
  714. /// 计算文件的sha256
  715. /// </summary>
  716. /// <param name="stream"></param>
  717. /// <returns></returns>
  718. public static string SHA256(this Stream stream)
  719. {
  720. using var fs = new BufferedStream(stream, 1048576);
  721. SHA256Managed sha = new SHA256Managed();
  722. byte[] checksum = sha.ComputeHash(fs);
  723. return BitConverter.ToString(checksum).Replace("-", string.Empty);
  724. }
  725. /// <summary>
  726. /// 获取数据流的MD5值
  727. /// </summary>
  728. /// <param name="stream"></param>
  729. /// <returns>MD5字符串</returns>
  730. public static string MDString(this Stream stream)
  731. {
  732. using var fs = new BufferedStream(stream, 1048576);
  733. using MD5 md5 = MD5.Create();
  734. byte[] bytes = md5.ComputeHash(fs);
  735. var mdstr = bytes.Aggregate("", (current, b) => current + b.ToString("x2"));
  736. stream.Position = 0;
  737. return mdstr;
  738. }
  739. #endregion
  740. #endregion MD5加密算法
  741. }
  742. /// <summary>
  743. /// RC2加密解密算法
  744. /// </summary>
  745. public static class RC2
  746. {
  747. private static ASCIIEncoding _asciiEncoding;
  748. private static byte[] _iv;
  749. private static byte[] _key;
  750. private static RC2CryptoServiceProvider _rc2Csp;
  751. private static UnicodeEncoding _textConverter;
  752. static RC2()
  753. {
  754. InitializeComponent();
  755. }
  756. private static void InitializeComponent()
  757. {
  758. _key = new byte[]
  759. {
  760. 106,
  761. 51,
  762. 25,
  763. 141,
  764. 157,
  765. 142,
  766. 23,
  767. 111,
  768. 234,
  769. 159,
  770. 187,
  771. 154,
  772. 215,
  773. 34,
  774. 37,
  775. 204
  776. };
  777. _iv = new byte[]
  778. {
  779. 135,
  780. 186,
  781. 133,
  782. 136,
  783. 184,
  784. 149,
  785. 153,
  786. 144
  787. };
  788. _asciiEncoding = new ASCIIEncoding();
  789. _textConverter = new UnicodeEncoding();
  790. _rc2Csp = new RC2CryptoServiceProvider();
  791. }
  792. #region 将文本数据加密后写入一个文件
  793. /// <summary>
  794. /// 将文本数据加密后写入一个文件,其中,这个文件是用InitBinFile建立的,这个文件将被分成十块,
  795. /// 用来分别保存10组不同的数据,第一个byte位保留,第2位到第21位分别用来存放每块数据的长度,但
  796. /// 一个byte的取值为0-127,所以,用两个byte来存放一个长度。
  797. /// </summary>
  798. /// <param name="toEncryptText">要加密的文本数据</param>
  799. /// <param name="filePath">要写入的文件</param>
  800. /// <param name="dataIndex">写入第几块,取值为1--10</param>
  801. /// <returns>是否操作成功</returns>
  802. public static bool EncryptToFile(this string toEncryptText, string filePath, int dataIndex)
  803. {
  804. var r = false;
  805. if ((dataIndex > 10) && (dataIndex < 1))
  806. {
  807. return r;
  808. }
  809. //打开要写入的文件,主要是为了保持原文件的内容不丢失
  810. var tmpFileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.None, 1024, true);
  811. var index = new byte[10261];
  812. //将读取的内容写到byte数组
  813. tmpFileStream.Read(index, 0, 10261);
  814. tmpFileStream.Close();
  815. //定义基本的加密转换运算
  816. using var Encryptor = _rc2Csp.CreateEncryptor(_key, _iv);
  817. var msEncrypt = new MemoryStream();
  818. //在此加密转换流中,加密将从csEncrypt,加密后,结果在msEncrypt流中。
  819. using var csEncrypt = new CryptoStream(msEncrypt, Encryptor, CryptoStreamMode.Write);
  820. //将要加密的文本转换成UTF-16 编码,保存在tmp数组。
  821. var tmp = _textConverter.GetBytes(toEncryptText);
  822. //将tmp输入csEncrypt,将通过Encryptor来加密。
  823. csEncrypt.Write(tmp, 0, tmp.Length);
  824. //输出到msEnctypt
  825. csEncrypt.FlushFinalBlock();
  826. //将流转成byte[]
  827. var encrypted = msEncrypt.ToArray();
  828. if (encrypted.Length > 1024)
  829. return false;
  830. //得到加密后数据的大小,将结果存在指定的位置。
  831. index[dataIndex * 2 - 1] = Convert.ToByte(Convert.ToString(encrypted.Length / 128));
  832. index[dataIndex * 2] = Convert.ToByte(Convert.ToString(encrypted.Length % 128));
  833. //将加密后的结果写入index(覆盖)
  834. for (var i = 0; i < encrypted.Length; i++)
  835. index[1024 * (dataIndex - 1) + 21 + i] = encrypted[i];
  836. //建立文件流
  837. tmpFileStream = new FileStream(filePath, FileMode.Truncate, FileAccess.Write, FileShare.None, 1024, true);
  838. //写文件
  839. tmpFileStream.Write(index, 0, 10261);
  840. tmpFileStream.Flush();
  841. r = true;
  842. tmpFileStream.Close();
  843. return r;
  844. }
  845. #endregion
  846. #region 从一个文件中解密出一段文本,其中,这个文件是由InitBinFile建立的,并且由 EncryptToFile加密的
  847. /// <summary>
  848. /// 从一个文件中解密出一段文本,其中,这个文件是由InitBinFile建立的,并且由 EncryptToFile加密的
  849. /// </summary>
  850. /// <param name="filePath">要解密的文件</param>
  851. /// <param name="dataIndex">要从哪一个块中解密</param>
  852. /// <returns>解密后的文本</returns>
  853. public static string DecryptFromFile(this string filePath, int dataIndex)
  854. {
  855. if (dataIndex > 10 && dataIndex < 1)
  856. {
  857. return "";
  858. }
  859. using var tmpFileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.None, 1024, true);
  860. using var decryptor = _rc2Csp.CreateDecryptor(_key, _iv);
  861. var msDecrypt = new MemoryStream();
  862. using var csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Write);
  863. var index = new byte[10261];
  864. tmpFileStream.Read(index, 0, 10261);
  865. var count = index[dataIndex * 2 - 1] * 128 + index[dataIndex * 2];
  866. var tmp = new byte[count];
  867. Array.Copy(index, 1024 * (dataIndex - 1) + 21, tmp, 0, count);
  868. csDecrypt.Write(tmp, 0, count);
  869. csDecrypt.FlushFinalBlock();
  870. var decrypted = msDecrypt.ToArray();
  871. return _textConverter.GetString(decrypted, 0, decrypted.Length);
  872. }
  873. #endregion
  874. #region 将一段文本加密后保存到一个文件
  875. /// <summary>
  876. /// 将一段文本加密后保存到一个文件
  877. /// </summary>
  878. /// <param name="toEncryptText">要加密的文本数据</param>
  879. /// <param name="filePath">要保存的文件</param>
  880. /// <returns>是否加密成功</returns>
  881. public static void EncryptToFile(this string toEncryptText, string filePath)
  882. {
  883. using var tmpFileStream = new FileStream(filePath, FileMode.OpenOrCreate, FileAccess.Write, FileShare.None, 1024, true);
  884. using var encryptor = _rc2Csp.CreateEncryptor(_key, _iv);
  885. var msEncrypt = new MemoryStream();
  886. using var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write);
  887. var tmp = _textConverter.GetBytes(toEncryptText);
  888. csEncrypt.Write(tmp, 0, tmp.Length);
  889. csEncrypt.FlushFinalBlock();
  890. var encrypted = msEncrypt.ToArray();
  891. tmpFileStream.Write(encrypted, 0, encrypted.Length);
  892. }
  893. #endregion
  894. #region 将一个被加密的文件解密
  895. /// <summary>
  896. /// 将一个被加密的文件解密
  897. /// </summary>
  898. /// <param name="filePath">要解密的文件</param>
  899. /// <returns>解密后的文本</returns>
  900. public static string DecryptFromFile(this string filePath)
  901. {
  902. using var tmpFileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.None, 1024, true);
  903. using var decryptor = _rc2Csp.CreateDecryptor(_key, _iv);
  904. var msDecrypt = new MemoryStream();
  905. using var csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Write);
  906. var tmp = new byte[tmpFileStream.Length];
  907. tmpFileStream.Read(tmp, 0, tmp.Length);
  908. csDecrypt.Write(tmp, 0, tmp.Length);
  909. csDecrypt.FlushFinalBlock();
  910. var decrypted = msDecrypt.ToArray();
  911. return _textConverter.GetString(decrypted, 0, decrypted.Length);
  912. }
  913. #endregion
  914. #region 将文本数据加密后写入一个文件
  915. /// <summary>
  916. /// 将文本数据加密后写入一个文件,其中,这个文件是用InitBinFile建立的,这个文件将被分成十块,
  917. /// 用来分别保存10组不同的数据,第一个byte位保留,第2位到第21位分别用来存放每块数据的长度,但
  918. /// 一个byte的取值为0-127,所以,用两个byte来存放一个长度。
  919. /// </summary>
  920. /// <param name="toEncryptText">要加密的文本数据</param>
  921. /// <param name="filePath">要写入的文件</param>
  922. /// <param name="dataIndex">写入第几块,取值为1--10</param>
  923. /// <param name="IV">初始化向量</param>
  924. /// <param name="Key">加密密匙</param>
  925. /// <returns>是否操作成功</returns>
  926. public static void EncryptToFile(this string toEncryptText, string filePath, int dataIndex, byte[] IV, byte[] Key)
  927. {
  928. if ((dataIndex > 10) && (dataIndex < 1))
  929. {
  930. return;
  931. }
  932. //打开要写入的文件,主要是为了保持原文件的内容不丢失
  933. using var fs = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.None, 1024, true);
  934. var index = new byte[10261];
  935. //将读取的内容写到byte数组
  936. fs.Read(index, 0, 10261);
  937. //定义基本的加密转换运算
  938. using var encryptor = _rc2Csp.CreateEncryptor(Key, IV);
  939. var msEncrypt = new MemoryStream();
  940. //在此加密转换流中,加密将从csEncrypt,加密后,结果在msEncrypt流中。
  941. using var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write);
  942. var tmp = _textConverter.GetBytes(toEncryptText);
  943. //将tmp输入csEncrypt,将通过Encryptor来加密。
  944. csEncrypt.Write(tmp, 0, tmp.Length);
  945. //输出到msEnctypt
  946. csEncrypt.FlushFinalBlock();
  947. //将流转成byte[]
  948. var encrypted = msEncrypt.ToArray();
  949. if (encrypted.Length > 1024)
  950. {
  951. return;
  952. }
  953. //得到加密后数据的大小,将结果存在指定的位置。
  954. index[dataIndex * 2 - 1] = Convert.ToByte(Convert.ToString(encrypted.Length / 128));
  955. index[dataIndex * 2] = Convert.ToByte(Convert.ToString(encrypted.Length % 128));
  956. //将加密后的结果写入index(覆盖)
  957. for (int i = 0; i < encrypted.Length; i++)
  958. {
  959. index[1024 * (dataIndex - 1) + 21 + i] = encrypted[i];
  960. }
  961. //建立文件流
  962. using var newStream = new FileStream(filePath, FileMode.Truncate, FileAccess.Write, FileShare.None, 1024, true);
  963. newStream.Write(index, 0, 10261);
  964. newStream.Flush();
  965. }
  966. #endregion
  967. #region 从一个文件中解密出一段文本
  968. /// <summary>
  969. /// 从一个文件中解密出一段文本,其中,这个文件是由InitBinFile建立的,并且由 EncryptToFile加密的
  970. /// </summary>
  971. /// <param name="filePath">要解密的文件</param>
  972. /// <param name="dataIndex">要从哪一个块中解密</param>
  973. /// <param name="iv">初始化向量</param>
  974. /// <param name="key">解密密匙</param>
  975. /// <returns>解密后的文本</returns>
  976. public static string DecryptFromFile(this string filePath, int dataIndex, byte[] iv, byte[] key)
  977. {
  978. if ((dataIndex > 10) && (dataIndex < 1))
  979. {
  980. return "";
  981. }
  982. using var tmpFileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.None, 1024, true);
  983. using var decryptor = _rc2Csp.CreateDecryptor(key, iv);
  984. var msDecrypt = new MemoryStream();
  985. using var csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Write);
  986. var index = new byte[10261];
  987. tmpFileStream.Read(index, 0, 10261);
  988. var count = index[dataIndex * 2 - 1] * 128 + index[dataIndex * 2];
  989. var tmp = new byte[count];
  990. Array.Copy(index, 1024 * (dataIndex - 1) + 21, tmp, 0, count);
  991. csDecrypt.Write(tmp, 0, count);
  992. csDecrypt.FlushFinalBlock();
  993. var decrypted = msDecrypt.ToArray();
  994. return _textConverter.GetString(decrypted, 0, decrypted.Length);
  995. }
  996. #endregion
  997. #region 将一段文本加密后保存到一个文件
  998. /// <summary>
  999. /// 将一段文本加密后保存到一个文件
  1000. /// </summary>
  1001. /// <param name="toEncryptText">要加密的文本数据</param>
  1002. /// <param name="filePath">要保存的文件</param>
  1003. /// <param name="iv">初始化向量</param>
  1004. /// <param name="key">加密密匙</param>
  1005. /// <returns>是否加密成功</returns>
  1006. public static void EncryptToFile(this string toEncryptText, string filePath, byte[] iv, byte[] key)
  1007. {
  1008. using var tmpFileStream = new FileStream(filePath, FileMode.OpenOrCreate, FileAccess.Write, FileShare.None, 1024, true);
  1009. using var encryptor = _rc2Csp.CreateEncryptor(key, iv);
  1010. var msEncrypt = new MemoryStream();
  1011. using var csEncrypt = new CryptoStream(msEncrypt, encryptor, CryptoStreamMode.Write);
  1012. var tmp = _textConverter.GetBytes(toEncryptText);
  1013. csEncrypt.Write(tmp, 0, tmp.Length);
  1014. csEncrypt.FlushFinalBlock();
  1015. var encrypted = msEncrypt.ToArray();
  1016. tmpFileStream.Write(encrypted, 0, encrypted.Length);
  1017. tmpFileStream.Flush();
  1018. }
  1019. #endregion
  1020. #region 将一个被加密的文件解密
  1021. /// <summary>
  1022. /// 将一个被加密的文件解密
  1023. /// </summary>
  1024. /// <param name="filePath">要解密的文件</param>
  1025. /// <param name="iv">初始化向量</param>
  1026. /// <param name="key">解密密匙</param>
  1027. /// <returns>解密后的文本</returns>
  1028. public static string DecryptFromFile(this string filePath, byte[] iv, byte[] key)
  1029. {
  1030. using var tmpFileStream = new FileStream(filePath, FileMode.Open, FileAccess.Read, FileShare.None, 1024, true);
  1031. using var decryptor = _rc2Csp.CreateDecryptor(key, iv);
  1032. var msDecrypt = new MemoryStream();
  1033. using var csDecrypt = new CryptoStream(msDecrypt, decryptor, CryptoStreamMode.Write);
  1034. var tmp = new byte[tmpFileStream.Length];
  1035. tmpFileStream.Read(tmp, 0, tmp.Length);
  1036. csDecrypt.Write(tmp, 0, tmp.Length);
  1037. csDecrypt.FlushFinalBlock();
  1038. var decrypted = msDecrypt.ToArray();
  1039. return _textConverter.GetString(decrypted, 0, decrypted.Length);
  1040. }
  1041. #endregion
  1042. #region 设置加密或解密的初始化向量
  1043. /// <summary>
  1044. /// 设置加密或解密的初始化向量
  1045. /// </summary>
  1046. /// <param name="s">长度等于8的ASCII字符集的字符串</param>
  1047. public static void SetIV(this string s)
  1048. {
  1049. if (s.Length != 8)
  1050. {
  1051. _iv = null;
  1052. return;
  1053. }
  1054. try
  1055. {
  1056. _iv = _asciiEncoding.GetBytes(s);
  1057. }
  1058. catch (Exception)
  1059. {
  1060. _iv = null;
  1061. }
  1062. }
  1063. #endregion
  1064. #region 设置加密或解密的密匙
  1065. /// <summary>
  1066. /// 设置加密或解密的密匙
  1067. /// </summary>
  1068. /// <param name="s">长度等于16的ASCII字符集的字符串</param>
  1069. public static void SetKey(this string s)
  1070. {
  1071. if (s.Length != 16)
  1072. {
  1073. _key = null;
  1074. return;
  1075. }
  1076. try
  1077. {
  1078. _key = _asciiEncoding.GetBytes(s);
  1079. }
  1080. catch (Exception)
  1081. {
  1082. _key = null;
  1083. }
  1084. }
  1085. #endregion
  1086. }
  1087. /// <summary>
  1088. /// 对称加密解密算法类
  1089. /// </summary>
  1090. public static class Rijndael
  1091. {
  1092. private static string _key;
  1093. private static SymmetricAlgorithm _mobjCryptoService;
  1094. /// <summary>
  1095. /// 对称加密类的构造函数
  1096. /// </summary>
  1097. public static void SymmetricMethod()
  1098. {
  1099. _mobjCryptoService = new RijndaelManaged();
  1100. _key = "Guz(%&hj7x89H$yuBI0456FtmaT5&fvHUFCy76*h%(HilJ$lhj!y6&(*jkP87jH7";
  1101. }
  1102. /// <summary>
  1103. /// 获得密钥
  1104. /// </summary>
  1105. /// <returns>密钥</returns>
  1106. private static byte[] GetLegalKey()
  1107. {
  1108. var sTemp = _key;
  1109. _mobjCryptoService.GenerateKey();
  1110. var bytTemp = _mobjCryptoService.Key;
  1111. var keyLength = bytTemp.Length;
  1112. if (sTemp.Length > keyLength)
  1113. {
  1114. sTemp = sTemp.Substring(0, keyLength);
  1115. }
  1116. else if (sTemp.Length < keyLength)
  1117. {
  1118. sTemp = sTemp.PadRight(keyLength, ' ');
  1119. }
  1120. return Encoding.ASCII.GetBytes(sTemp);
  1121. }
  1122. /// <summary>
  1123. /// 获得初始向量IV
  1124. /// </summary>
  1125. /// <returns>初试向量IV</returns>
  1126. private static byte[] GetLegalIV()
  1127. {
  1128. var sTemp = "E4ghj*Ghg7!rNIfb&95GUY86GfghUber57HBh(u%g6HJ($jhWk7&!hg4ui%$hjk";
  1129. _mobjCryptoService.GenerateIV();
  1130. var bytTemp = _mobjCryptoService.IV;
  1131. var ivLength = bytTemp.Length;
  1132. if (sTemp.Length > ivLength)
  1133. {
  1134. sTemp = sTemp.Substring(0, ivLength);
  1135. }
  1136. else if (sTemp.Length < ivLength)
  1137. {
  1138. sTemp = sTemp.PadRight(ivLength, ' ');
  1139. }
  1140. return Encoding.ASCII.GetBytes(sTemp);
  1141. }
  1142. /// <summary>
  1143. /// 加密方法
  1144. /// </summary>
  1145. /// <param name="source">待加密的串</param>
  1146. /// <returns>经过加密的串</returns>
  1147. public static string Encrypto(this string source)
  1148. {
  1149. var bytIn = Encoding.UTF8.GetBytes(source);
  1150. var ms = new MemoryStream();
  1151. _mobjCryptoService.Key = GetLegalKey();
  1152. _mobjCryptoService.IV = GetLegalIV();
  1153. using var encrypto = _mobjCryptoService.CreateEncryptor();
  1154. using var cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Write);
  1155. cs.Write(bytIn, 0, bytIn.Length);
  1156. cs.FlushFinalBlock();
  1157. var bytOut = ms.ToArray();
  1158. return Convert.ToBase64String(bytOut);
  1159. }
  1160. /// <summary>
  1161. /// 解密方法
  1162. /// </summary>
  1163. /// <param name="source">待解密的串</param>
  1164. /// <returns>经过解密的串</returns>
  1165. public static string Decrypto(this string source)
  1166. {
  1167. var bytIn = Convert.FromBase64String(source);
  1168. var ms = new MemoryStream(bytIn, 0, bytIn.Length);
  1169. _mobjCryptoService.Key = GetLegalKey();
  1170. _mobjCryptoService.IV = GetLegalIV();
  1171. using var encrypto = _mobjCryptoService.CreateDecryptor();
  1172. using var cs = new CryptoStream(ms, encrypto, CryptoStreamMode.Read);
  1173. using var sr = new StreamReader(cs);
  1174. return sr.ReadToEnd();
  1175. }
  1176. }
  1177. }