|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
Доброго! Мистера pation'а прошу не читать этот пост, а то у него будет извержение. Всем остальным приятного использования! Выкладываю класс для криптографических операций, который позволяет: 1. шифровать/дешифровать текст 2. шифровать/дешифровать объект с бинарной сериализацией 3. шифровать/дешифровать файл Всё остальное смотрите в примере! пример Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. 37. 38. 39. 40. 41. 42. 43. 44. 45. 46. 47. 48. 49. 50. 51. 52. 53. 54. 55. 56. 57. 58.
класс для примера Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12.
Сразу предупрежу, что данный класс портировался с проекта 8-милетней давности с языка VB.NET и красоту я там не наводил (разве что чуть-чуть) + содержатся куски кода с MSDN и форумов исходник Код: c# 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. 19. 20. 21. 22. 23. 24. 25. 26. 27. 28. 29. 30. 31. 32. 33. 34. 35. 36. 37. 38. 39. 40. 41. 42. 43. 44. 45. 46. 47. 48. 49. 50. 51. 52. 53. 54. 55. 56. 57. 58. 59. 60. 61. 62. 63. 64. 65. 66. 67. 68. 69. 70. 71. 72. 73. 74. 75. 76. 77. 78. 79. 80. 81. 82. 83. 84. 85. 86. 87. 88. 89. 90. 91. 92. 93. 94. 95. 96. 97. 98. 99. 100. 101. 102. 103. 104. 105. 106. 107. 108. 109. 110. 111. 112. 113. 114. 115. 116. 117. 118. 119. 120. 121. 122. 123. 124. 125. 126. 127. 128. 129. 130. 131. 132. 133. 134. 135. 136. 137. 138. 139. 140. 141. 142. 143. 144. 145. 146. 147. 148. 149. 150. 151. 152. 153. 154. 155. 156. 157. 158. 159. 160. 161. 162. 163. 164. 165. 166. 167. 168. 169. 170. 171. 172. 173. 174. 175. 176. 177. 178. 179. 180. 181. 182. 183. 184. 185. 186. 187. 188. 189. 190. 191. 192. 193. 194. 195. 196. 197. 198. 199. 200. 201. 202. 203. 204. 205. 206. 207. 208. 209. 210. 211. 212. 213. 214. 215. 216. 217. 218. 219. 220. 221. 222. 223. 224. 225. 226. 227. 228. 229. 230. 231. 232. 233. 234. 235. 236. 237. 238. 239. 240. 241. 242. 243. 244. 245. 246. 247. 248. 249. 250. 251. 252. 253. 254. 255. 256. 257. 258. 259. 260. 261. 262. 263. 264. 265. 266. 267. 268. 269. 270. 271. 272. 273. 274. 275. 276. 277. 278. 279. 280. 281. 282. 283. 284. 285. 286. 287. 288. 289. 290. 291. 292. 293. 294. 295. 296. 297. 298. 299. 300. 301. 302. 303. 304. 305. 306. 307. 308. 309. 310. 311. 312. 313. 314. 315. 316. 317. 318. 319. 320. 321. 322. 323. 324. 325. 326. 327. 328. 329. 330. 331. 332. 333. 334. 335. 336. 337. 338. 339. 340. 341. 342. 343. 344. 345. 346. 347. 348. 349. 350. 351. 352. 353. 354. 355. 356. 357. 358. 359. 360. 361. 362. 363. 364. 365. 366. 367. 368. 369. 370. 371. 372. 373. 374. 375. 376. 377. 378. 379. 380. 381. 382. 383. 384. 385. 386. 387. 388. 389. 390. 391. 392. 393. 394. 395. 396. 397. 398. 399. 400. 401. 402. 403. 404. 405. 406. 407. 408. 409. 410. 411. 412. 413. 414. 415. 416. 417. 418. 419. 420. 421. 422.
Если вам понравился класс и вы его дополнили и сделали лучше, то скиньте мне на почту pavel_61981@mail.ru, вдруг пригодится ;) ... |
|||
:
Нравится:
Не нравится:
|
|||
01.11.2017, 12:40 |
|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
__Pavel__, кому, простите, нужна Ваша говнонадстройка над CryptoStream? Код без использования Вашего "модуля" получается компактнее и удобнее для чтения, чем с ним. Реализуйте несколько наследников от SymmetricAlgorithm что-ли, в .NET реализовано довольно мало из популярных. Тогда можно будет говорить о какой-то пользе от Вашего кода. ... |
|||
:
Нравится:
Не нравится:
|
|||
01.11.2017, 16:41 |
|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
С дуба рухнули, что ли - пароль в ключ переводить через MD5-хэш? MD5 давно уже ненадежен, и такие ключи компрометируются на раз. Откройте для себя стандарт PBKDF2 , и реализующий его класс Rfc2898DeriveBytes ... |
|||
:
Нравится:
Не нравится:
|
|||
01.11.2017, 17:19 |
|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
Сон Веры ПавловныС дуба рухнули, что ли - пароль в ключ переводить через MD5-хэш? MD5 давно уже ненадежен, и такие ключи компрометируются на раз. Откройте для себя стандарт PBKDF2 , и реализующий его класс Rfc2898DeriveBytes Написано же, что реализация старая, может есть какие то ограничения связанные с MD5, лично я использую SHA256-512 и не парюсь. А так любой алгоритм хеширования можно компрометировать, просто у MD5 маленькая размерность и куча rainbow баз ... |
|||
:
Нравится:
Не нравится:
|
|||
01.11.2017, 17:22 |
|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
__Pavel__Мистера pation'а прошу не читать этот постсписок персон нон-грата будет пополнен ... |
|||
:
Нравится:
Не нравится:
|
|||
01.11.2017, 17:23 |
|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
Roman Mejtesможет есть какие то ограничения связанные с MD5, лично я использую SHA256-512 Roman MejtesА так любой алгоритм хеширования можно компрометировать Алгоритмы хэширования не предназначены для получения ключа шифрования. От слова "совсем". Они только могут принимать в этой операции опосредованное участие. Причины - ну, хотя бы высокая скорость алгоритмов хэширования, в разы повышающая количество попыток брутфорса в единицу времени (а в PBKDF2 специально внесены замедляющие генерацию алгоритмы - по первой ссылке выше об этом написано). Плюс дополнительная энтропия как параметр метода, плюс количество задаваемых итераций генерации - всё это сказывается на криптостойкости ключа. И при этом, надо заметить, использовать Rfc2898DeriveBytes ничуть не сложнее, чем считать хэшсумму. Roman Mejtesи не парюсь Может, ну тогда нафиг этот AES? Использовать ROT-13, и не париться? ... |
|||
:
Нравится:
Не нравится:
|
|||
01.11.2017, 17:41 |
|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
Код без использования Вашего "модуля" получается компактнее и удобнее для чтения, чем с ним. У вас что-то со зрением. С дуба рухнули, что ли - пароль в ключ переводить через MD5-хэш? Данный недочет исправляется в считанные секунды-минуты. На тот момент мне нужно было получить сгенерированую строку на 32 символа из любой строки, он с этим справлялся. П.С. идите лесом, п**деть не мешки ворочать! Если надстройка вам не нравится, то напишите лучше и выложите, т.к. их нет, всю инфу нужно искать по кускам! Для тех кому не нужна супер надежность (хотя мне кажется она здесь на высоком уровне, кроме MD5), но нужно незапариваясь в одну строку кода шифровать данные, она очень даже сойдет. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.11.2017, 12:21 |
|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
__Pavel__напишите лучше и выложите Зачем? Когда нужно что-то зашифровать - пишется типовой код в десяток строк на основе стандартных классов. Таскать по всем проектам ради этого класс считаю нецелесообразным. __Pavel__т.к. их нет, всю инфу нужно искать по кускам! https://www.google.ru/search?q=AesCryptoServiceProvider -> по первой же ссылке в выдаче попадаем в справку по классу - там есть всё, что нужно знать для использования класса (если не углубляться в нюансы использования различных CipherMode и режимов Padding, а в случае RijndaelManaged еще и FeedbackSize - но в классе выше этого всего нет). ... |
|||
:
Нравится:
Не нравится:
|
|||
02.11.2017, 15:24 |
|
ГОТОВЫЙ класс для криптографических операций (текст, объекты, файлы)
|
|||
---|---|---|---|
#18+
__Pavel__Код без использования Вашего "модуля" получается компактнее и удобнее для чтения, чем с ним. У вас что-то со зрением. Т.е. пример из сообщения выше 20919732 Вас не убеждает? Про стойкость алгоритма я не говорю, а то, что "данный класс портировался с проекта 8-милетней давности с языка VB.NET" ни разу не аргумент, если Вы выкладываете поделку на всеобщее обозрение. Для сериализации и записи в файл никакие "дополнительные классы" не нужны, в .NET это делается очень удобно и компактно. Если ты (это я обобщаю, а не про Вас лично говорю) этого не умеешь, то программирование - это явно не твое. ... |
|||
:
Нравится:
Не нравится:
|
|||
02.11.2017, 16:04 |
|
|
start [/forum/topic.php?fid=20&fpage=37&tid=1399641]: |
0ms |
get settings: |
8ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
36ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
57ms |
get tp. blocked users: |
2ms |
others: | 332ms |
total: | 473ms |
0 / 0 |