Encrypt.cs 51 KB

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