{"id":459423,"date":"2025-05-13T03:03:33","date_gmt":"2025-05-13T03:03:33","guid":{"rendered":"http:\/\/savepearlharbor.com\/?p=459423"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-29T21:00:00","slug":"","status":"publish","type":"post","link":"https:\/\/savepearlharbor.com\/?p=459423","title":{"rendered":"<span>Cryptohack. \u0420\u0435\u0448\u0435\u043d\u0438\u0435 Oh SNAP. \u0410\u0442\u0430\u043a\u0430 \u0424\u043b\u044e\u0440\u0435\u0440\u0430-\u041c\u0430\u043d\u0442\u0438\u043d\u0430-\u0428\u0430\u043c\u0438\u0440\u0430 (Fluhrer, Mantin, Shamir)<\/span>"},"content":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041f\u0440\u0438\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e, \u0425\u0430\u0431\u0440! \u0412 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0445 \u0441\u0442\u0430\u0442\u044c\u044f\u0445 \u044f \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u043b \u0440\u0435\u0436\u0438\u043c\u044b \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0434\u043b\u044f \u0431\u043b\u043e\u0447\u043d\u044b\u0445 \u0448\u0438\u0444\u0440\u043e\u0432, \u043f\u043e\u0441\u0442\u0435\u043f\u0435\u043d\u043d\u043e \u0441\u0434\u0432\u0438\u0433\u0430\u044f\u0441\u044c \u0432 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 \u0440\u0435\u0436\u0438\u043c\u043e\u0432, \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u044e\u0449\u0438\u0445 \u0431\u043b\u043e\u0447\u043d\u044b\u0435 \u0448\u0438\u0444\u0440\u044b \u0432 \u043f\u043e\u0442\u043e\u043a\u043e\u0432\u044b\u0435. \u0412 \u043d\u043e\u0432\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0432 \u0444\u043e\u043a\u0443\u0441\u0435 \u0431\u0443\u0434\u0435\u0442 \u0447\u0438\u0441\u0442\u043e \u043f\u043e\u0442\u043e\u043a\u043e\u0432\u044b\u0439 \u0448\u0438\u0444\u0440 &#8212; RC4. \u042f \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u043e \u0441\u0430\u043c\u043e\u043c \u0448\u0438\u0444\u0440\u0435, \u0430 \u0442\u0430\u043a\u0436\u0435 \u043e\u0431 \u0430\u0442\u0430\u043a\u0435 FMS \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0438 \u0435\u0451 \u0434\u043b\u044f \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0437\u0430\u0434\u0430\u0447\u0438 Oh SNAP \u0441 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u044b <a href=\"https:\/\/cryptohack.org\/challenges\/aes\/\" rel=\"noopener noreferrer nofollow\">Cryptohack<\/a>.<\/p>\n<h2>\u0428\u0438\u0444\u0440 RC4<\/h2>\n<p>RC4 &#8212; \u043f\u043e\u0442\u043e\u043a\u043e\u0432\u044b\u0439 \u0448\u0438\u0444\u0440, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0430\u043d\u043d\u044b\u0439 \u0420\u043e\u043d\u043e\u043c \u0420\u0438\u0432\u0435\u0441\u0442\u043e\u043c \u0432 1987 \u0433\u043e\u0434\u0443, \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0431\u044b\u043b\u0430 \u0441\u043a\u0440\u044b\u0442\u0430 \u043a\u043e\u043c\u043c\u0435\u0440\u0447\u0435\u0441\u043a\u043e\u0439 \u0442\u0430\u0439\u043d\u043e\u0439 \u0434\u043e 1994 \u0433\u043e\u0434\u0430, \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u043e\u043d\u0430 \u0443\u0442\u0435\u043a\u043b\u0430 \u0432 \u0441\u0435\u0442\u044c. \u041a \u043d\u0430\u0447\u0430\u043b\u0443 2000\u0445 \u0433\u043e\u0434\u043e\u0432 \u043e\u043d \u0441\u0442\u0430\u043b \u043e\u0434\u043d\u0438\u043c \u0438\u0437 \u0441\u0430\u043c\u044b\u0445 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u0448\u0438\u0444\u0440\u043e\u0432, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u0432 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u043d\u043e\u043c \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0435\u043d\u0438\u0438. \u0422\u0430\u043a\u0430\u044f \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u043e\u0441\u0442\u044c \u0431\u044b\u043b\u0430 \u0432\u043e \u043c\u043d\u043e\u0433\u043e\u043c \u043e\u0431\u0443\u0441\u043b\u043e\u0432\u043b\u0435\u043d\u0430 \u0435\u0433\u043e \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u0439, \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0433\u0438\u0431\u043a\u043e\u0441\u0442\u044c\u044e \u0438 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u044c\u044e &#8212; \u0441\u0435\u043a\u0440\u0435\u0442\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0432 ~1700 \u0431\u0438\u0442 \u043f\u0440\u0438 \u043a\u043b\u044e\u0447\u0435 \u0432 8 \u0431\u0430\u0439\u0442.<\/p>\n<p>\u0428\u0438\u0444\u0440 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0438\u0437 \u0434\u0432\u0443\u0445 \u0447\u0430\u0441\u0442\u0435\u0439: \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 (KSA) \u0438 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438 \u0433\u0430\u043c\u043c\u044b (PRGA). \u041f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u0435\u0434\u0438\u043d\u043e\u0436\u0434\u044b \u0434\u043b\u044f \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0438 \u0448\u0438\u0444\u0440\u0430 \u043a \u0440\u0430\u0431\u043e\u0442\u0435. \u041e\u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0434\u043b\u044f \u0448\u0438\u0444\u0440\u0430 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c \u0432 256 \u0431\u0430\u0439\u0442 \u0438 \u043f\u0435\u0440\u0435\u043c\u0435\u0448\u0438\u0432\u0430\u0435\u0442 \u044d\u0442\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u043c \u043a\u043b\u044e\u0447\u043e\u043c \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<blockquote>\n<p>\u0412 \u043e\u0431\u0449\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0448\u0438\u0444\u0440 RC4 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u044b &#171;\u0441\u043b\u043e\u0432\u0430&#187; \u0438 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0442\u0430\u043a\u0436\u0435 \u043c\u043e\u0436\u0435\u0442 \u0438\u043c\u0435\u0442\u044c \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u044b. \u0412 \u0434\u0430\u043d\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043d\u0435 \u0431\u0443\u0434\u0443 \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0431\u043e\u0431\u0449\u0451\u043d\u043d\u044b\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438, \u0440\u0430\u0437\u043c\u0435\u0440 \u0441\u043b\u043e\u0432\u0430 \u0432 \u043d\u0430\u0448\u0435\u0439 \u0437\u0430\u0434\u0430\u0447\u0435 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0431\u0430\u0439\u0442, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c 256, \u0435\u0433\u043e \u0438 \u0431\u0443\u0434\u0435\u043c \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c. <\/p>\n<p>\u0417\u0430 \u0431\u043e\u043b\u0435\u0435 \u043e\u0431\u0449\u0438\u043c \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435\u043c \u0448\u0438\u0444\u0440\u0430 \u0438 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0439 \u0430\u0442\u0430\u043a\u0438 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u044e \u043e\u0437\u043d\u0430\u043a\u043e\u043c\u0438\u0442\u044c\u0441\u044f \u0441 \u043b\u0438\u0442\u0435\u0440\u0430\u0442\u0443\u0440\u043e\u0439 \u0438\u0437 \u0441\u043f\u0438\u0441\u043a\u0430 \u0432 \u043a\u043e\u043d\u0446\u0435 \u0441\u0442\u0430\u0442\u044c\u0438.<\/p>\n<\/blockquote>\n<pre><code class=\"python\">def ksa(key: bytes):   S = [i for i in range(256)]      j = 0   for i in range(256):     j = (j + S[i] + key[i % len(key)]) % 256     S[i], S[j] = S[j], S[i]<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435 \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0431\u0430\u0439\u0442\u0430 \u0433\u0430\u043c\u043c\u044b \u043a\u043b\u044e\u0447\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 PRGA<\/p>\n<pre><code class=\"python\">def prga():   i = 0   j = 0   while True:     i = (i + 1) % 256     j = j + S[i]     S[i], S[j] = S[j], S[i]     yield S[(S[i] + S[j]) % 256]<\/code><\/pre>\n<h2>\u0423\u044f\u0437\u0432\u0438\u043c\u043e\u0441\u0442\u044c \u0432 KSA<\/h2>\n<p>\u0412 2001 \u0433\u043e\u0434\u0443 \u0421\u043a\u043e\u0442\u0442 \u0424\u043b\u044e\u0440\u0435\u0440, \u0418\u0442\u0441\u0438\u043a \u041c\u0430\u043d\u0442\u0438\u043d \u0438 \u0410\u0434\u0438 \u0428\u0430\u043c\u0438\u0440 \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043b\u0438 \u0441\u0442\u0430\u0442\u044c\u044e \u043f\u043e\u0434 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435\u043c &#171;Weakness in the Key Scheduling Algorithm of RC4&#187;. \u0418\u0437 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0430 \u0441\u0440\u0430\u0437\u0443 \u043f\u043e\u043d\u044f\u0442\u043d\u043e \u0447\u0442\u043e \u0438\u0445 \u0441\u0442\u0430\u0442\u044c\u044f \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0435\u0442 \u043f\u0435\u0440\u0432\u0443\u044e \u0447\u0430\u0441\u0442\u044c \u0448\u0438\u0444\u0440\u0430 &#8212; \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443 KSA. \u042f \u043d\u0435 \u0431\u0443\u0434\u0443 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u0441\u0442\u0430\u0442\u044c\u044e, \u043e\u043f\u0438\u0448\u0443 \u043b\u0438\u0448\u044c \u0435\u0451 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b \u0438 \u0441\u0430\u043c\u0443 \u0438\u0434\u0435\u044e \u0430\u0442\u0430\u043a\u0438.<\/p>\n<p>\u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u0430\u0432\u0442\u043e\u0440\u044b \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u0443\u044e\u0442 \u043e\u0441\u043b\u0430\u0431\u043b\u0435\u043d\u043d\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u044b KSA \u0438 \u0441\u0442\u0440\u043e\u0433\u043e \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442, \u0447\u0442\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u043a\u043b\u044e\u0447\u0430, \u043f\u0440\u043e\u0445\u043e\u0434\u044f \u0447\u0435\u0440\u0435\u0437 \u044d\u0442\u0443 \u043e\u0441\u043b\u0430\u0431\u043b\u0435\u043d\u043d\u0443\u044e \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443, \u0441\u043e\u0437\u0434\u0430\u044e\u0442 \u0442\u0430\u043a \u0436\u0435 \u0432\u043f\u043e\u043b\u043d\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u0432 \u0441\u0435\u043a\u0440\u0435\u0442\u043d\u043e\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u0448\u0438\u0444\u0440\u0430 \u0438 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0432\u0435\u043d\u043d\u043e \u044d\u0442\u043e \u0432\u043b\u0438\u044f\u0435\u0442 \u043d\u0430 \u0448\u0438\u0444\u0440\u043e\u0442\u0435\u043a\u0441\u0442. \u0414\u0440\u0443\u0433\u0438\u043c\u0438 \u0441\u043b\u043e\u0432\u0430\u043c\u0438, \u0435\u0441\u043b\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0439 \u043a\u043b\u044e\u0447 \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u0435\u0442 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u043c \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u043c, \u0442\u043e \u0438 \u0441\u0435\u043a\u0440\u0435\u0442\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043f\u043e\u0441\u043b\u0435 \u043e\u0441\u043b\u0430\u0431\u043b\u0435\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u044b KSA \u0442\u0430\u043a\u0436\u0435 \u0431\u0443\u0434\u0435\u0442 \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u0442\u044c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u043c \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u043c.<\/p>\n<p>\u0414\u0430\u043b\u0435\u0435 \u043e\u043d\u0438 \u0432\u043d\u043e\u0441\u044f\u0442 \u043f\u043e\u043f\u0440\u0430\u0432\u043a\u0443 \u0434\u043b\u044f \u043d\u0435\u043e\u0441\u043b\u0430\u0431\u043b\u0435\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u044b KSA \u0438 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442, \u0447\u0442\u043e \u0442\u0435 \u0436\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0431\u0438\u0442 \u0432 \u043a\u043b\u044e\u0447\u0435 \u0431\u0443\u0434\u0443\u0442 \u043f\u0440\u043e\u043d\u0438\u043a\u0430\u0442\u044c \u0432 \u0441\u0435\u043a\u0440\u0435\u0442\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435, \u043e\u0434\u043d\u0430\u043a\u043e \u0442\u0435\u043f\u0435\u0440\u044c \u0441 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c\u044e. \u0418 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u044d\u0442\u0430 \u0432\u043f\u043e\u043b\u043d\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u0430\u044f (<img decoding=\"async\" class=\"formula inline\" source=\"\\geq 2\/5\" alt=\"\\geq 2\/5\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/974\/a7a\/f34\/974a7af345dd0dd390e7f83595e937be.svg\" width=\"50\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/974\/a7a\/f34\/974a7af345dd0dd390e7f83595e937be.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/974\/a7a\/f34\/974a7af345dd0dd390e7f83595e937be.svg 781w\" loading=\"lazy\" decode=\"async\"\/>).<\/p>\n<p>\u0412 \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0445 \u0441\u0435\u043a\u0446\u0438\u044f\u0445 \u0441\u0442\u0430\u0442\u044c\u0438 \u043e\u043f\u0438\u0441\u0430\u043d\u044b \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0434\u043b\u044f \u0430\u0442\u0430\u043a\u0438 \u043d\u0430 \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u0435 RC4. \u0412 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0430\u0442\u0430\u043a\u0438 \u0441 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435\u043c \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e\u0433\u043e \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u044e\u0449\u0435\u0433\u043e \u0432\u0435\u043a\u0442\u043e\u0440\u0430 \u0432 \u0441\u043b\u0443\u0447\u0430\u044f\u0445 \u043a\u043e\u0433\u0434\u0430 \u0432\u0435\u043a\u0442\u043e\u0440 \u043f\u0440\u0438\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043a \u043a\u043b\u044e\u0447\u0443 \u0432 \u043d\u0430\u0447\u0430\u043b\u0435 \u0438\u043b\u0438 \u0432 \u043a\u043e\u043d\u0446\u0435. \u0418\u043c\u0435\u043d\u043d\u043e \u0430\u0442\u0430\u043a\u0443 \u043d\u0430 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0439 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u044e\u0449\u0438\u0439 \u0432\u0435\u043a\u0442\u043e\u0440 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0434\u043b\u044f \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0437\u0430\u0434\u0430\u0447\u0438 \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u044d\u0442\u0430 \u0430\u0442\u0430\u043a\u0430 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 FMS (Fluhrer-Mantin-Shamir) \u0438 \u043e\u0431\u0440\u0435\u043b\u0430 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u043e\u0441\u0442\u044c, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043e\u043d\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0430\u0441\u044c \u0434\u043b\u044f <a href=\"https:\/\/www.cs.jhu.edu\/~astubble\/600.412\/s-c-papers\/wireless2.pdf\" rel=\"noopener noreferrer nofollow\">\u0432\u0437\u043b\u043e\u043c\u0430 \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f WiFi \u0441\u0435\u0442\u0435\u0439 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0438\u0445 \u0437\u0430\u0449\u0438\u0442\u0443 WEP<\/a>.<\/p>\n<h2>\u0410\u0442\u0430\u043a\u0430 FMS<\/h2>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u0447\u0443\u0442\u044c \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043f\u0440\u043e\u0439\u0434\u0451\u043c\u0441\u044f \u043f\u043e \u043c\u0435\u0445\u0430\u043d\u0438\u043a\u0435 \u0441\u0430\u043c\u043e\u0439 \u0430\u0442\u0430\u043a\u0438. \u0421\u0443\u0442\u044c \u0435\u0451 \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c:<\/p>\n<ul>\n<li>\n<p>\u0415\u0441\u043b\u0438 IV \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0445\u043e\u0442\u044f \u0431\u044b \u0438\u0437 \u0442\u0440\u0451\u0445 \u0431\u0430\u0439\u0442 \u0438 \u0438\u043c\u0435\u0435\u0442 \u0432\u0438\u0434 <img decoding=\"async\" class=\"formula inline\" source=\"(3, 255, X)\" alt=\"(3, 255, X)\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3c8\/94a\/e36\/3c894ae3660ed4a48bf250ed3b96b191.svg\" width=\"88\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3c8\/94a\/e36\/3c894ae3660ed4a48bf250ed3b96b191.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3c8\/94a\/e36\/3c894ae3660ed4a48bf250ed3b96b191.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, \u0433\u0434\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"X\" alt=\"X\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/327\/4ad\/fcc\/3274adfccc4c49e2b3a2677cc61d0cad.svg\" width=\"17\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/327\/4ad\/fcc\/3274adfccc4c49e2b3a2677cc61d0cad.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/327\/4ad\/fcc\/3274adfccc4c49e2b3a2677cc61d0cad.svg 781w\" loading=\"lazy\" decode=\"async\"\/> &#8212; \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0439 \u0431\u0430\u0439\u0442; \u0438 \u043c\u044b \u0438\u043c\u0435\u0435\u043c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0443\u0433\u0430\u0434\u0430\u0442\u044c \u0438\u043b\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u0433\u0430\u043c\u043c\u044b \u043a\u043b\u044e\u0447\u0430 (\u043c\u044b \u0437\u043d\u0430\u0435\u043c \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043e\u0442\u043a\u0440\u044b\u0442\u043e\u0433\u043e \u0442\u0435\u043a\u0441\u0442\u0430) <img decoding=\"async\" class=\"formula inline\" source=\"keyStreamByte\" alt=\"keyStreamByte\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/18a\/21e\/c01\/18a21ec017ac840d1f0efa68dbde1c8b.svg\" width=\"135\" height=\"21\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/18a\/21e\/c01\/18a21ec017ac840d1f0efa68dbde1c8b.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/18a\/21e\/c01\/18a21ec017ac840d1f0efa68dbde1c8b.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, \u0442\u043e \u0441 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c\u044e \u043e\u043a\u043e\u043b\u043e 5% \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430 <img decoding=\"async\" class=\"formula inline\" source=\"K_0\" alt=\"K_0\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c01\/985\/38b\/c0198538bc6c0ad07d855769b33c86ef.svg\" width=\"25\" height=\"20\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c01\/985\/38b\/c0198538bc6c0ad07d855769b33c86ef.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c01\/985\/38b\/c0198538bc6c0ad07d855769b33c86ef.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u043f\u043e \u0444\u043e\u0440\u043c\u0443\u043b\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"K_0 = keyStreamByte - 6 - X \\pmod {256}\" alt=\"K_0 = keyStreamByte - 6 - X \\pmod {256}\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5d2\/a03\/4f0\/5d2a034f028e84f4b56b95280bc47f8a.svg\" width=\"372\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5d2\/a03\/4f0\/5d2a034f028e84f4b56b95280bc47f8a.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5d2\/a03\/4f0\/5d2a034f028e84f4b56b95280bc47f8a.svg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u043a\u043b\u044e\u0447\u0430, \u0432\u0442\u043e\u0440\u043e\u0439 \u0431\u0430\u0439\u0442 <img decoding=\"async\" class=\"formula inline\" source=\"K_1\" alt=\"K_1\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b4a\/46a\/392\/b4a46a3927740d13a7e3b86bb38d354a.svg\" width=\"25\" height=\"19\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b4a\/46a\/392\/b4a46a3927740d13a7e3b86bb38d354a.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b4a\/46a\/392\/b4a46a3927740d13a7e3b86bb38d354a.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u0435\u0441\u043b\u0438 IV \u0438\u043c\u0435\u0435\u0442 \u0432\u0438\u0434 <img decoding=\"async\" class=\"formula inline\" source=\"(4, 255, X)\" alt=\"(4, 255, X)\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/252\/aeb\/29c\/252aeb29ce5120f6fb7f81fb5482e120.svg\" width=\"88\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/252\/aeb\/29c\/252aeb29ce5120f6fb7f81fb5482e120.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/252\/aeb\/29c\/252aeb29ce5120f6fb7f81fb5482e120.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u043f\u043e \u0444\u043e\u0440\u043c\u0443\u043b\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"K_1 = keyStreamByte - 10 - X - K_0 \\pmod {256}\" alt=\"K_1 = keyStreamByte - 10 - X - K_0 \\pmod {256}\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e8c\/e0f\/325\/e8ce0f3258cce7def778e22f0a0d7080.svg\" width=\"431\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e8c\/e0f\/325\/e8ce0f3258cce7def778e22f0a0d7080.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e8c\/e0f\/325\/e8ce0f3258cce7def778e22f0a0d7080.svg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<\/li>\n<li>\n<p>\u041e\u0431\u043e\u0431\u0449\u0451\u043d\u043d\u0430\u044f \u0444\u043e\u0440\u043c\u0430 IV: <img decoding=\"async\" class=\"formula inline\" source=\"(A + 3, 255, X)\" alt=\"(A + 3, 255, X)\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/da4\/e96\/49f\/da4e9649f0794e54fd7ca64a30a632b8.svg\" width=\"127\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/da4\/e96\/49f\/da4e9649f0794e54fd7ca64a30a632b8.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/da4\/e96\/49f\/da4e9649f0794e54fd7ca64a30a632b8.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, \u0433\u0434\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"\u0410\" alt=\"\u0410\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b6f\/b5b\/917\/b6fb5b917a8c7e9ea3264cecf41bd5ef.svg\" width=\"11\" height=\"27\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b6f\/b5b\/917\/b6fb5b917a8c7e9ea3264cecf41bd5ef.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/b6f\/b5b\/917\/b6fb5b917a8c7e9ea3264cecf41bd5ef.svg 781w\" loading=\"lazy\" decode=\"async\"\/> &#8212; \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0443\u0436\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u044b\u0445 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430.<\/p>\n<\/li>\n<li>\n<p>\u041e\u0431\u0449\u0430\u044f \u0444\u043e\u0440\u043c\u0443\u043b\u0430 \u0434\u043b\u044f \u0431\u0430\u0439\u0442\u0430 \u043a\u043b\u044e\u0447\u0430:<img decoding=\"async\" class=\"formula inline\" source=\"O - j - S[i]\" alt=\"O - j - S[i]\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d09\/444\/b8c\/d09444b8c9bb7db770feb8e0d1b25555.svg\" width=\"101\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d09\/444\/b8c\/d09444b8c9bb7db770feb8e0d1b25555.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d09\/444\/b8c\/d09444b8c9bb7db770feb8e0d1b25555.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, \u0433\u0434\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"O\" alt=\"O\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6c9\/f11\/557\/6c9f115572a939840fb0e5300237b47c.svg\" width=\"15\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6c9\/f11\/557\/6c9f115572a939840fb0e5300237b47c.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6c9\/f11\/557\/6c9f115572a939840fb0e5300237b47c.svg 781w\" loading=\"lazy\" decode=\"async\"\/> &#8212; \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u0433\u0430\u043c\u043c\u044b \u043a\u043b\u044e\u0447\u0430, <img decoding=\"async\" class=\"formula inline\" source=\"j\" alt=\"j\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a33\/685\/66f\/a3368566f9370c09e29572ff448f1a3e.svg\" width=\"8\" height=\"20\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a33\/685\/66f\/a3368566f9370c09e29572ff448f1a3e.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a33\/685\/66f\/a3368566f9370c09e29572ff448f1a3e.svg 781w\" loading=\"lazy\" decode=\"async\"\/> &#8212; \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u0430 <img decoding=\"async\" class=\"formula inline\" source=\"j\" alt=\"j\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a1b\/5ed\/e74\/a1b5ede74c94749b6b724adde36c828c.svg\" width=\"8\" height=\"20\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a1b\/5ed\/e74\/a1b5ede74c94749b6b724adde36c828c.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a1b\/5ed\/e74\/a1b5ede74c94749b6b724adde36c828c.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0432 KSA \u043f\u043e\u0441\u043b\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"A + 3\" alt=\"A + 3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/81c\/4e0\/6c8\/81c4e06c8c69857583d8a43481ce26fd.svg\" width=\"48\" height=\"19\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/81c\/4e0\/6c8\/81c4e06c8c69857583d8a43481ce26fd.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/81c\/4e0\/6c8\/81c4e06c8c69857583d8a43481ce26fd.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439, <img decoding=\"async\" class=\"formula inline\" source=\"S[i]\" alt=\"S[i]\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/573\/d08\/03d\/573d0803d6084d0e42717ea12580d05d.svg\" width=\"30\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/573\/d08\/03d\/573d0803d6084d0e42717ea12580d05d.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/573\/d08\/03d\/573d0803d6084d0e42717ea12580d05d.svg 781w\" loading=\"lazy\" decode=\"async\"\/> &#8212; \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0431\u0430\u0439\u0442\u0430 \u0432 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u0448\u0438\u0444\u0440\u0430 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0443 <img decoding=\"async\" class=\"formula inline\" source=\"i\" alt=\"i\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6fd\/e5e\/dc6\/6fde5edc6c5760e407c1fde4d85cc068.svg\" width=\"7\" height=\"16\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6fd\/e5e\/dc6\/6fde5edc6c5760e407c1fde4d85cc068.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/6fd\/e5e\/dc6\/6fde5edc6c5760e407c1fde4d85cc068.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u043f\u043e\u0441\u043b\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"A + 3\" alt=\"A + 3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a25\/448\/c63\/a25448c6305d71fc7a0a51f11c0e444d.svg\" width=\"48\" height=\"19\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a25\/448\/c63\/a25448c6305d71fc7a0a51f11c0e444d.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a25\/448\/c63\/a25448c6305d71fc7a0a51f11c0e444d.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439. KSA \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u0442\u0441\u044f \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0443\u0436\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0445 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430. \u0422\u043e \u0435\u0441\u0442\u044c \u0432 KSA \u043c\u044b \u043f\u0435\u0440\u0435\u0434\u0430\u0451\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"IV + knownKey\" alt=\"IV + knownKey\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a88\/173\/9c5\/a881739c56c249c7fa02061d374544dc.svg\" width=\"142\" height=\"21\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a88\/173\/9c5\/a881739c56c249c7fa02061d374544dc.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a88\/173\/9c5\/a881739c56c249c7fa02061d374544dc.svg 781w\" loading=\"lazy\" decode=\"async\"\/>. \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0434\u043b\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u043a\u043b\u044e\u0447\u0430 \u043c\u044b \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u043c 3 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 KSA \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0439 IV \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043a\u043b\u044e\u0447\u0430. \u0414\u043b\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u043f\u0440\u043e\u0432\u043e\u0434\u0438\u043c \u0443\u0436\u0435 4 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043a\u043b\u044e\u0447\u0430 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0430\u0446\u0438\u044e IV \u0438 \u0443\u0436\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430, \u0438 \u0442. \u0434.<\/p>\n<\/li>\n<\/ul>\n<p>\u0427\u0442\u043e\u0431\u044b \u043f\u043e\u043d\u044f\u0442\u044c \u043e\u0442\u043a\u0443\u0434\u0430 \u0432\u0441\u0451 \u044d\u0442\u043e \u0431\u0435\u0440\u0451\u0442\u0441\u044f \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 KSA \u043f\u0440\u0438 IV = (3, 255, X). \u0414\u0435\u0440\u0436\u0438\u0442\u0435 \u0432 \u0443\u043c\u0435, \u0447\u0442\u043e IV \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432 \u043d\u0430\u0447\u0430\u043b\u043e \u043a\u043b\u044e\u0447\u0430, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 <img decoding=\"async\" class=\"formula inline\" source=\"K_0\" alt=\"K_0\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/04b\/2e0\/380\/04b2e0380ff1596b22e4bd0d1deac596.svg\" width=\"25\" height=\"20\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/04b\/2e0\/380\/04b2e0380ff1596b22e4bd0d1deac596.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/04b\/2e0\/380\/04b2e0380ff1596b22e4bd0d1deac596.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"K_1\" alt=\"K_1\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/aca\/82e\/432\/aca82e4327d470c5486c113f61402411.svg\" width=\"25\" height=\"19\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/aca\/82e\/432\/aca82e4327d470c5486c113f61402411.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/aca\/82e\/432\/aca82e4327d470c5486c113f61402411.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0438 <img decoding=\"async\" class=\"formula inline\" source=\"K_2\" alt=\"K_2\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/fd2\/c10\/924\/fd2c109245c9de17c904e7b6aecab6e9.svg\" width=\"25\" height=\"19\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/fd2\/c10\/924\/fd2c109245c9de17c904e7b6aecab6e9.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/fd2\/c10\/924\/fd2c109245c9de17c904e7b6aecab6e9.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0440\u0430\u0432\u043d\u044b <img decoding=\"async\" class=\"formula inline\" source=\"3\" alt=\"3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/13a\/dc6\/b94\/13adc6b94a18dddf692be709ea02f261.svg\" width=\"10\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/13a\/dc6\/b94\/13adc6b94a18dddf692be709ea02f261.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/13a\/dc6\/b94\/13adc6b94a18dddf692be709ea02f261.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"255\" alt=\"255\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/67c\/64e\/94b\/67c64e94b2f8bed77a8aaf34e5776714.svg\" width=\"29\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/67c\/64e\/94b\/67c64e94b2f8bed77a8aaf34e5776714.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/67c\/64e\/94b\/67c64e94b2f8bed77a8aaf34e5776714.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0438 <img decoding=\"async\" class=\"formula inline\" source=\"X\" alt=\"X\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/49e\/7f8\/00f\/49e7f800fcf74c62688f5f2c3ec21e64.svg\" width=\"17\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/49e\/7f8\/00f\/49e7f800fcf74c62688f5f2c3ec21e64.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/49e\/7f8\/00f\/49e7f800fcf74c62688f5f2c3ec21e64.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e.<\/p>\n<p>\u0421\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 <img decoding=\"async\" class=\"formula inline\" source=\"S\" alt=\"S\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/035\/5a5\/7b8\/0355a57b8339efbd43319da4620bf0d7.svg\" width=\"13\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/035\/5a5\/7b8\/0355a57b8339efbd43319da4620bf0d7.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/035\/5a5\/7b8\/0355a57b8339efbd43319da4620bf0d7.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0442\u0430\u043a (\u0441\u0432\u0435\u0440\u0445\u0443 \u0438\u043d\u0434\u0435\u043a\u0441, \u0441\u043d\u0438\u0437\u0443 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435)<\/p>\n<figure class=\"full-width\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/5eb\/829\/ab3\/5eb829ab318aa2d2ecac9e0df34080d9.png\" width=\"844\" height=\"247\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/5eb\/829\/ab3\/5eb829ab318aa2d2ecac9e0df34080d9.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/5eb\/829\/ab3\/5eb829ab318aa2d2ecac9e0df34080d9.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<p>\u0412\u043e \u0432\u0440\u0435\u043c\u044f \u043f\u0435\u0440\u0432\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 <img decoding=\"async\" class=\"formula inline\" source=\"i = 0\" alt=\"i = 0\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/2bf\/980\/dc6\/2bf980dc60d5ea5519ce5a3ed5892b13.svg\" width=\"43\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/2bf\/980\/dc6\/2bf980dc60d5ea5519ce5a3ed5892b13.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/2bf\/980\/dc6\/2bf980dc60d5ea5519ce5a3ed5892b13.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"j = j + S[i] + K[i] = 0 + S[0] + K[0] = 0 + 0 + 3 = 3\" alt=\"j = j + S[i] + K[i] = 0 + S[0] + K[0] = 0 + 0 + 3 = 3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d14\/46d\/c24\/d1446dc24c9a1e01d699f72d23be59ff.svg\" width=\"450\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d14\/46d\/c24\/d1446dc24c9a1e01d699f72d23be59ff.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d14\/46d\/c24\/d1446dc24c9a1e01d699f72d23be59ff.svg 781w\" loading=\"lazy\" decode=\"async\"\/>. \u0414\u0430\u043b\u0435\u0435 \u0432 <img decoding=\"async\" class=\"formula inline\" source=\"S\" alt=\"S\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/830\/097\/0b6\/8300970b663f715474cd4584990c1433.svg\" width=\"13\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/830\/097\/0b6\/8300970b663f715474cd4584990c1433.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/830\/097\/0b6\/8300970b663f715474cd4584990c1433.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f \u043c\u0435\u0441\u0442\u0430\u043c\u0438 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0441 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c\u0438 <img decoding=\"async\" class=\"formula inline\" source=\"i\" alt=\"i\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d10\/cb2\/764\/d10cb27642739201e2fda7906450e5da.svg\" width=\"7\" height=\"16\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d10\/cb2\/764\/d10cb27642739201e2fda7906450e5da.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d10\/cb2\/764\/d10cb27642739201e2fda7906450e5da.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0438 <img decoding=\"async\" class=\"formula inline\" source=\"j\" alt=\"j\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/af6\/4fe\/a34\/af64fea3462f532a1f1588a555798d3b.svg\" width=\"8\" height=\"20\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/af6\/4fe\/a34\/af64fea3462f532a1f1588a555798d3b.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/af6\/4fe\/a34\/af64fea3462f532a1f1588a555798d3b.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435<\/p>\n<figure class=\"full-width\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/7f6\/68c\/392\/7f668c392b9c5f2fed1a6436223b1fab.png\" width=\"849\" height=\"778\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/7f6\/68c\/392\/7f668c392b9c5f2fed1a6436223b1fab.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/7f6\/68c\/392\/7f668c392b9c5f2fed1a6436223b1fab.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<p>\u0412\u0442\u043e\u0440\u0430\u044f \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f: <img decoding=\"async\" class=\"formula inline\" source=\"i = 1\" alt=\"i = 1\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/759\/153\/8fa\/7591538fa895b6bfd1970b8084fc1e5d.svg\" width=\"43\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/759\/153\/8fa\/7591538fa895b6bfd1970b8084fc1e5d.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/759\/153\/8fa\/7591538fa895b6bfd1970b8084fc1e5d.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"j = 3 + S[1] + K[1] = 3 + 1 + 255 = 3 \\pmod {256}\" alt=\"j = 3 + S[1] + K[1] = 3 + 1 + 255 = 3 \\pmod {256}\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d98\/642\/d7f\/d98642d7f482d6b2ae66a4e55e885b3d.svg\" width=\"433\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d98\/642\/d7f\/d98642d7f482d6b2ae66a4e55e885b3d.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d98\/642\/d7f\/d98642d7f482d6b2ae66a4e55e885b3d.svg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<figure class=\"full-width\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/928\/46f\/6f6\/92846f6f6f9c5cdcf140600cceabfb39.png\" width=\"832\" height=\"883\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/928\/46f\/6f6\/92846f6f6f9c5cdcf140600cceabfb39.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/928\/46f\/6f6\/92846f6f6f9c5cdcf140600cceabfb39.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<p>\u0422\u0440\u0435\u0442\u044c\u044f \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f: <img decoding=\"async\" class=\"formula inline\" source=\"i = 2\" alt=\"i = 2\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/110\/9fb\/ba5\/1109fbba524233c4cbce71d7ae3d580d.svg\" width=\"43\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/110\/9fb\/ba5\/1109fbba524233c4cbce71d7ae3d580d.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/110\/9fb\/ba5\/1109fbba524233c4cbce71d7ae3d580d.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"j = 3 + S[2] + K[2] = 3 + 2 + X = 5 + X \" alt=\"j = 3 + S[2] + K[2] = 3 + 2 + X = 5 + X \" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3ab\/777\/f0f\/3ab777f0f4e3efc426c468f506c8fd2a.svg\" width=\"350\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3ab\/777\/f0f\/3ab777f0f4e3efc426c468f506c8fd2a.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/3ab\/777\/f0f\/3ab777f0f4e3efc426c468f506c8fd2a.svg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<figure class=\"full-width\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/fb3\/906\/606\/fb3906606bdd14bbd18ae7c24a2637ea.png\" width=\"1309\" height=\"1034\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/fb3\/906\/606\/fb3906606bdd14bbd18ae7c24a2637ea.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/fb3\/906\/606\/fb3906606bdd14bbd18ae7c24a2637ea.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<p>\u041d\u0430\u043a\u043e\u043d\u0435\u0446, \u0447\u0435\u0442\u0432\u0451\u0440\u0442\u0430\u044f \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f: <img decoding=\"async\" class=\"formula inline\" source=\"i = 3\" alt=\"i = 3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/7e7\/ae8\/d42\/7e7ae8d42019584e05f79ae0a8608a00.svg\" width=\"43\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/7e7\/ae8\/d42\/7e7ae8d42019584e05f79ae0a8608a00.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/7e7\/ae8\/d42\/7e7ae8d42019584e05f79ae0a8608a00.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"j = 5 + X + S[3] + K[3] = 5 + X + 1 + K[3] = 6 + X + K[3]\" alt=\"j = 5 + X + S[3] + K[3] = 5 + X + 1 + K[3] = 6 + X + K[3]\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5bd\/5ef\/2f6\/5bd5ef2f60d4680c54a15ac6bdfe4bea.svg\" width=\"515\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5bd\/5ef\/2f6\/5bd5ef2f60d4680c54a15ac6bdfe4bea.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/5bd\/5ef\/2f6\/5bd5ef2f60d4680c54a15ac6bdfe4bea.svg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<figure class=\"full-width\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/4d9\/3f0\/c96\/4d93f0c96282cde4eb5db0440600877c.png\" width=\"2099\" height=\"1125\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/4d9\/3f0\/c96\/4d93f0c96282cde4eb5db0440600877c.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/4d9\/3f0\/c96\/4d93f0c96282cde4eb5db0440600877c.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<p>\u0410 \u0442\u0435\u043f\u0435\u0440\u044c \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u0447\u0442\u043e KSA \u043d\u0430 \u044d\u0442\u043e\u043c \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b\u0430\u0441\u044c. \u0415\u0441\u043b\u0438 \u043c\u044b \u043f\u043e\u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0434\u0438\u043d \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0439 \u0433\u0430\u043c\u043c\u044b \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u043e\u0439 PRGA, \u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435<\/p>\n<ol>\n<li>\n<p><img decoding=\"async\" class=\"formula inline\" source=\"j = 0\" alt=\"j = 0\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/9f9\/dd5\/f6f\/9f9dd5f6f3371cf8fe09b0c784ab61ca.svg\" width=\"43\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/9f9\/dd5\/f6f\/9f9dd5f6f3371cf8fe09b0c784ab61ca.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/9f9\/dd5\/f6f\/9f9dd5f6f3371cf8fe09b0c784ab61ca.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"j = 0\" alt=\"j = 0\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/formulas\/6\/6e\/6e0\/6e0572428c877b3f78918d5e49c27953.svg\" width=\"auto\" height=\"auto\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/formulas\/6\/6e\/6e0\/6e0572428c877b3f78918d5e49c27953.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/formulas\/6\/6e\/6e0\/6e0572428c877b3f78918d5e49c27953.svg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<\/li>\n<li>\n<p><img decoding=\"async\" class=\"formula inline\" source=\"i = 1\" alt=\"i = 1\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/099\/cb9\/543\/099cb9543800006f862db68d99a65157.svg\" width=\"43\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/099\/cb9\/543\/099cb9543800006f862db68d99a65157.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/099\/cb9\/543\/099cb9543800006f862db68d99a65157.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"j = S[i] = 0\" alt=\"j = S[i] = 0\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/380\/399\/744\/38039974452c486c60ba59dc4edec652.svg\" width=\"101\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/380\/399\/744\/38039974452c486c60ba59dc4edec652.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/380\/399\/744\/38039974452c486c60ba59dc4edec652.svg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<\/li>\n<li>\n<p><img decoding=\"async\" class=\"formula inline\" source=\"S[i]\" alt=\"S[i]\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/cbe\/9b7\/d19\/cbe9b7d19f24c7e8f9c27a15a4b18c62.svg\" width=\"30\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/cbe\/9b7\/d19\/cbe9b7d19f24c7e8f9c27a15a4b18c62.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/cbe\/9b7\/d19\/cbe9b7d19f24c7e8f9c27a15a4b18c62.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"S[j]\" alt=\"S[j]\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/aee\/ded\/b5e\/aeededb5ee76d94cd8af89e8d90b0cd9.svg\" width=\"32\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/aee\/ded\/b5e\/aeededb5ee76d94cd8af89e8d90b0cd9.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/aee\/ded\/b5e\/aeededb5ee76d94cd8af89e8d90b0cd9.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f \u043c\u0435\u0441\u0442\u0430\u043c\u0438, \u043d\u043e \u044d\u0442\u043e \u043d\u0435 \u0432\u043b\u0438\u044f\u0435\u0442 \u043d\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430.<\/p>\n<\/li>\n<li>\n<p>\u041f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0439 \u0433\u0430\u043c\u043c\u044b \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0432\u0435\u043d <img decoding=\"async\" class=\"formula inline\" source=\"S[S[1] + S[0]] = S[3] = 6 + X + K_3\" alt=\"S[S[1] + S[0]] = S[3] = 6 + X + K_3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/195\/14f\/104\/19514f1041851141887376e26b854b72.svg\" width=\"299\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/195\/14f\/104\/19514f1041851141887376e26b854b72.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/195\/14f\/104\/19514f1041851141887376e26b854b72.svg 781w\" loading=\"lazy\" decode=\"async\"\/><\/p>\n<\/li>\n<\/ol>\n<p>\u041f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0439 \u0433\u0430\u043c\u043c\u044b <img decoding=\"async\" class=\"formula inline\" source=\"keyStreamByte\" alt=\"keyStreamByte\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/76a\/051\/813\/76a05181310602aa6ac1fc853f05a8ea.svg\" width=\"135\" height=\"21\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/76a\/051\/813\/76a05181310602aa6ac1fc853f05a8ea.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/76a\/051\/813\/76a05181310602aa6ac1fc853f05a8ea.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0441\u0432\u044f\u0437\u0430\u043d \u0441 \u043f\u0435\u0440\u0432\u044b\u043c (\u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u043c \u043d\u0430\u043c) \u0431\u0430\u0439\u0442\u043e\u043c \u043a\u043b\u044e\u0447\u0430 \u0444\u043e\u0440\u043c\u0443\u043b\u043e\u0439 <img decoding=\"async\" class=\"formula inline\" source=\"keyStreamByte = 6 + X + K_3\" alt=\"keyStreamByte = 6 + X + K_3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/605\/82e\/2f5\/60582e2f5b86995c0e0e6fcf21abcc74.svg\" width=\"261\" height=\"21\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/605\/82e\/2f5\/60582e2f5b86995c0e0e6fcf21abcc74.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/605\/82e\/2f5\/60582e2f5b86995c0e0e6fcf21abcc74.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, \u0438 \u0435\u0441\u043b\u0438 \u043c\u044b \u0437\u043d\u0430\u0435\u043c \u0447\u0435\u043c\u0443 \u0440\u0430\u0432\u0435\u043d \u044d\u0442\u043e\u0442 \u0431\u0430\u0439\u0442, \u0442\u043e \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043b\u0435\u0433\u043a\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c <img decoding=\"async\" class=\"formula inline\" source=\"K_3 = keyStreamByte - 6 - X \\pmod {256}\" alt=\"K_3 = keyStreamByte - 6 - X \\pmod {256}\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/36c\/ba9\/a5f\/36cba9a5f4c9cdd159aec44e589c8aec.svg\" width=\"372\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/36c\/ba9\/a5f\/36cba9a5f4c9cdd159aec44e589c8aec.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/36c\/ba9\/a5f\/36cba9a5f4c9cdd159aec44e589c8aec.svg 781w\" loading=\"lazy\" decode=\"async\"\/>. \u0422\u043e \u0435\u0441\u0442\u044c \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0442\u043e \u0436\u0435 \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u044f \u043f\u0440\u0438\u0432\u0451\u043b \u0432 \u043d\u0430\u0447\u0430\u043b\u0435 \u0441\u0435\u043a\u0446\u0438\u0438. \u0424\u043e\u0440\u043c\u0443\u043b\u0443 \u0434\u043b\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0442\u0430\u043a\u0438\u043c \u0436\u0435 \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u0435\u0441\u043b\u0438 \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c IV \u043d\u0430 <img decoding=\"async\" class=\"formula inline\" source=\"(4, 255, X)\" alt=\"(4, 255, X)\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/364\/0f7\/30e\/3640f730e1b520858eba39633ed23588.svg\" width=\"88\" height=\"22\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/364\/0f7\/30e\/3640f730e1b520858eba39633ed23588.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/364\/0f7\/30e\/3640f730e1b520858eba39633ed23588.svg 781w\" loading=\"lazy\" decode=\"async\"\/>.<\/p>\n<p>\u0415\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u0430\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 KSA \u043d\u0435 \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043f\u043e\u0441\u043b\u0435 4 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439, \u0430 \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442 \u0435\u0449\u0451 252 \u0446\u0438\u043a\u043b\u0430. \u0412 \u043b\u044e\u0431\u043e\u0439 \u0438\u0437 \u044d\u0442\u0438\u0445 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u0438\u043d\u0434\u0435\u043a\u0441\u044b <img decoding=\"async\" class=\"formula inline\" source=\"S_0\" alt=\"S_0\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/835\/c01\/1d2\/835c011d2a05ba5b1bfc1ab6f96433f5.svg\" width=\"21\" height=\"20\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/835\/c01\/1d2\/835c011d2a05ba5b1bfc1ab6f96433f5.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/835\/c01\/1d2\/835c011d2a05ba5b1bfc1ab6f96433f5.svg 781w\" loading=\"lazy\" decode=\"async\"\/>, <img decoding=\"async\" class=\"formula inline\" source=\"S_1\" alt=\"S_1\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/182\/3f2\/dc5\/1823f2dc55568ae2317f516a0ede9562.svg\" width=\"21\" height=\"19\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/182\/3f2\/dc5\/1823f2dc55568ae2317f516a0ede9562.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/182\/3f2\/dc5\/1823f2dc55568ae2317f516a0ede9562.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u0438 <img decoding=\"async\" class=\"formula inline\" source=\"S_3\" alt=\"S_3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/0a6\/11a\/53b\/0a611a53b1ccfe2fe8ed3ab9b8dc335f.svg\" width=\"21\" height=\"20\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/0a6\/11a\/53b\/0a611a53b1ccfe2fe8ed3ab9b8dc335f.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/0a6\/11a\/53b\/0a611a53b1ccfe2fe8ed3ab9b8dc335f.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u043c\u043e\u0433\u0443\u0442 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c\u0441\u044f \u0438 \u0442\u043e\u0433\u0434\u0430 \u0444\u043e\u0440\u043c\u0443\u043b\u0430 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c. \u0415\u0441\u043b\u0438 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u0442\u044c, \u0447\u0442\u043e \u0432 \u043b\u044e\u0431\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u0438\u043d\u0434\u0435\u043a\u0441 <img decoding=\"async\" class=\"formula inline\" source=\"j\" alt=\"j\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e91\/37b\/7bd\/e9137b7bd44f86d11d04bd299b1b20f1.svg\" width=\"8\" height=\"20\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e91\/37b\/7bd\/e9137b7bd44f86d11d04bd299b1b20f1.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/e91\/37b\/7bd\/e9137b7bd44f86d11d04bd299b1b20f1.svg 781w\" loading=\"lazy\" decode=\"async\"\/> \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0442\u043e \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0432 \u044d\u0442\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u0438\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 0, 1 \u0438\u043b\u0438 3 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 <img decoding=\"async\" class=\"formula inline\" source=\"\\frac{253}{256}\" alt=\"\\frac{253}{256}\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a22\/14b\/1be\/a2214b1be901477126bafc2f1e3305b1.svg\" width=\"36\" height=\"43\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a22\/14b\/1be\/a2214b1be901477126bafc2f1e3305b1.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/a22\/14b\/1be\/a2214b1be901477126bafc2f1e3305b1.svg 781w\" loading=\"lazy\" decode=\"async\"\/>. \u0421\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0437\u0430 \u043d\u0438\u043a\u0430\u043a\u043e\u0439 \u0438\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f \u0437\u0430 252 \u0442\u0430\u043a\u0438\u0445 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 <img decoding=\"async\" class=\"formula inline\" source=\"(\\frac{253}{256}) ^ {252} \\approx 0.05\" alt=\"(\\frac{253}{256}) ^ {252} \\approx 0.05\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c82\/224\/569\/c82224569194b39ffb71df046ea02ef7.svg\" width=\"135\" height=\"43\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c82\/224\/569\/c82224569194b39ffb71df046ea02ef7.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/c82\/224\/569\/c82224569194b39ffb71df046ea02ef7.svg 781w\" loading=\"lazy\" decode=\"async\"\/>. \u041e\u0442\u0441\u044e\u0434\u0430 \u0432\u044b\u0442\u0435\u043a\u0430\u0435\u0442 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0443\u0441\u043f\u0435\u0448\u043d\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430 \u0432 5%.<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043e\u0431\u0440\u0430\u0442\u0438\u043c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u043c\u044b \u0438\u043c\u0435\u0435\u043c 5% \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430, \u0432 95% \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435. \u042d\u0442\u0430 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0430 \u043c\u0435\u0436\u0434\u0443 255 \u0434\u0440\u0443\u0433\u0438\u043c\u0438 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u043c\u0438 \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u043c\u0438 \u0431\u0430\u0439\u0442\u0430\u043c\u0438. \u0421\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u043a\u0430\u043a\u043e\u0433\u043e-\u043b\u0438\u0431\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u0431\u0443\u0434\u0435\u0442 \u0441\u0438\u043b\u044c\u043d\u043e \u043d\u0438\u0436\u0435 5% (<img decoding=\"async\" class=\"formula inline\" source=\"\\approx 0.3\" alt=\"\\approx 0.3\" src=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d02\/e11\/64a\/d02e1164ac5178706a075bd1f875f208.svg\" width=\"46\" height=\"17\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d02\/e11\/64a\/d02e1164ac5178706a075bd1f875f208.svg 780w,&#10;       https:\/\/habrastorage.org\/getpro\/habr\/upload_files\/d02\/e11\/64a\/d02e1164ac5178706a075bd1f875f208.svg 781w\" loading=\"lazy\" decode=\"async\"\/>%, \u0435\u0441\u043b\u0438 \u043c\u0435\u043d\u044f \u043d\u0435 \u043f\u043e\u0434\u0432\u043e\u0434\u044f\u0442 \u043c\u043e\u0438 \u0440\u0430\u0441\u0447\u0451\u0442\u044b). \u0418\u043c\u0435\u043d\u043d\u043e \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043e\u0442\u0434\u0435\u043b\u0438\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043e\u0442 \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0445 &#8212; \u0441\u043e\u0431\u0440\u0430\u0442\u044c \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u0438 \u043d\u0430\u0439\u0442\u0438 \u0442\u043e\u0442, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0447\u0430\u0449\u0435 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445.<\/p>\n<h2>\u0420\u0435\u0448\u0435\u043d\u0438\u0435 \u0437\u0430\u0434\u0430\u0447\u0438<\/h2>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0435\u0440\u0435\u0439\u0434\u0451\u043c \u043a \u0441\u0430\u043c\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0435. \u041d\u0430\u043c \u0434\u0430\u043d \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u043a\u043e\u0434<\/p>\n<pre><code class=\"python\">from Crypto.Cipher import ARC4   FLAG = ?   @chal.route('\/oh_snap\/send_cmd\/&lt;ciphertext&gt;\/&lt;nonce&gt;\/') def send_cmd(ciphertext, nonce):     if not ciphertext:         return {\"error\": \"You must specify a ciphertext\"}     if not nonce:         return {\"error\": \"You must specify a nonce\"}      ciphertext = bytes.fromhex(ciphertext)     nonce = bytes.fromhex(nonce)      cipher = ARC4.new(nonce + FLAG.encode())     cmd = cipher.decrypt(ciphertext)     if cmd == b\"ping\":         return {\"msg\": \"Pong!\"}     else:         return {\"error\": f\"Unknown command: {cmd.hex()}\"}<\/code><\/pre>\n<p>\u041d\u0430\u043c \u0434\u0430\u043d\u0430 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u0442\u044c (\u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0447\u0442\u043e \u0437\u0430\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u0442\u044c) \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e RC4 (ARC4 \u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0447\u0442\u043e RC4). \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043a\u043b\u044e\u0447\u0430 \u0434\u043b\u044f \u0448\u0438\u0444\u0440\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043f\u0440\u0438\u0441\u043b\u0430\u043d\u043d\u044b\u0439 \u043d\u0430\u043c\u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0439 IV (nonce), \u043a \u043a\u043e\u0442\u043e\u0440\u043e\u043c\u0443 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d \u0444\u043b\u0430\u0433. \u0415\u0441\u043b\u0438 \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u043d\u0435 \u0440\u0430\u0432\u0435\u043d <code>ping<\/code>, \u0442\u043e \u0441\u0435\u0440\u0432\u0435\u0440 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u0435 \u043e\u0431 \u043e\u0448\u0438\u0431\u043a\u0435 \u0441 \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c.<\/p>\n<p>\u0424\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0430\u043c \u0434\u0430\u043d\u0430 \u0438\u0434\u0435\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u0440\u0435\u0434\u0430 \u0434\u043b\u044f \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0430\u0442\u0430\u043a\u0438 FMS. \u041c\u044b \u0441\u0430\u043c\u0438 \u043c\u043e\u0436\u0435\u043c \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0435 \u043d\u0430\u043c IV, \u0430 \u0442\u0430\u043a\u0436\u0435 \u043d\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0443\u0433\u0430\u0434\u044b\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0439 \u0433\u0430\u043c\u043c\u044b, \u0442.\u043a. \u043c\u044b \u0437\u043d\u0430\u0435\u043c \u0438 \u043e\u0442\u043a\u0440\u044b\u0442\u044b\u0439 \u0438 \u0437\u0430\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442\u044b, \u0430 \u0437\u043d\u0430\u0447\u0438\u0442 \u043c\u043e\u0436\u0435\u043c \u0435\u0433\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c. \u041e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043a\u043e\u0434, \u043d\u0435 \u0431\u0443\u0434\u0435\u043c \u0436\u0435 \u043c\u044b \u044d\u0442\u043e \u0434\u0435\u043b\u0430\u0442\u044c \u0432\u0440\u0443\u0447\u043d\u0443\u044e.<\/p>\n<p>\u041a\u043e\u0434 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0442\u0430\u043a<\/p>\n<pre><code class=\"python\">import requests import json from time import sleep import os from ptCrypt.Attacks.Symmetric.RC4.FluhrerMantinShamirAttack import FluhrerMantinShamirAttack   baseAddress = \"https:\/\/aes.cryptohack.org\/oh_snap\/send_cmd\"  class Callback(FluhrerMantinShamirAttack.Callback):      def __init__(self):         self.text = os.urandom(16).hex()         self.lastFoundByte = None         self.sleepTime = 1      def applyNonce(self, nonce):         try:             request = f\"{baseAddress}\/{self.text}\/{nonce}\"             response = requests.get(request)                          firstByteCommand = json.loads(response.content)[\"error\"].strip(\"Unknown command: \")[:2]             keyStreamByte = int(firstByteCommand, 16) ^ int(self.text[:2], 16)              return keyStreamByte         except Exception as t:             print(t)             sleep(self.sleepTime)             self.sleepTime = min(60, self.sleepTime * 2)             return self.applyNonce(nonce)                   def shouldContinue(self):         return self.lastFoundByte != b\"}\"      def onKeyByteFound(self, keyByte):         self.lastFoundByte = bytes([keyByte])         print(f\"Found byte: {chr(keyByte)}\")          def onFinished(key):         print(f\"Found key: {key}\")   attack = FluhrerMantinShamirAttack(Callback(), b\"\") attack.run()<\/code><\/pre>\n<p>\u0421\u0430\u043c\u0430 \u0430\u0442\u0430\u043a\u0430 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 <a href=\"https:\/\/github.com\/0awawa0\/ptCrypt\" rel=\"noopener noreferrer nofollow\">ptCrypt<\/a> \u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 \u0432\u0435\u0440\u0441\u0438\u0438 0.0.14.1. \u041a\u043b\u0430\u0441\u0441 <code>FluhrerMantinShamirAttack<\/code> \u0441\u0430\u043c \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 IV \u043d\u0443\u0436\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u0442 \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u044b\u0435 \u0431\u0430\u0439\u0442\u044b \u043a\u043b\u044e\u0447\u0430, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e \u0441\u0443\u0442\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0441 \u0441\u0435\u0440\u0432\u0435\u0440\u043e\u043c \u0438 \u043f\u0430\u0440\u0443 \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0434\u043b\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044f \u0445\u043e\u0434\u0430 \u0430\u0442\u0430\u043a\u0438.<\/p>\n<p>\u0427\u0443\u0442\u044c \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043f\u0440\u043e \u043a\u043e\u0434:<\/p>\n<ol>\n<li>\n<p>\u041a\u043b\u0430\u0441\u0441 <code>Callback<\/code> \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u044b\u0432\u0430\u0435\u0442 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043a\u043e\u043b\u0431\u0435\u043a\u0430 <code>FluhrerMantinShamirAttack.Callback<\/code> \u0434\u043b\u044f \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u043a\u043b\u0430\u0441\u0441\u043e\u043c \u0430\u0442\u0430\u043a\u0438.<\/p>\n<\/li>\n<li>\n<p>\u041c\u0435\u0442\u043e\u0434 <code>applyNonce(self, nonce)<\/code> \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 IV \u043d\u0443\u0436\u043d\u043e\u0433\u043e \u0444\u043e\u0440\u043c\u0430\u0442\u0430 \u0438 \u043e\u0442\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440 \u0434\u043b\u044f \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u0437\u0430\u0442\u0435\u043c \u0438\u0437 \u0437\u0430\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u0442\u0435\u043a\u0441\u0442\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u0442 \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u0433\u0430\u043c\u043c\u044b \u043a\u043b\u044e\u0447\u0430 \u0438 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0432 \u043a\u043b\u0430\u0441\u0441 \u0430\u0442\u0430\u043a\u0438 \u0434\u043b\u044f \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0439 \u043e\u0431\u0440\u0430\u0431\u043e\u0442\u043a\u0438. \u0422\u0430\u043a \u043a\u0430\u043a \u043f\u0440\u0438 \u043c\u043d\u043e\u0433\u043e\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u044b\u0445 \u0437\u0430\u043f\u0440\u043e\u0441\u0430\u0445 \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440 \u043c\u043e\u0436\u0435\u0442 \u0432\u044b\u0441\u0442\u0440\u0435\u043b\u0438\u0442\u044c \u043e\u0433\u0440\u0430\u043d\u0438\u0447\u0435\u043d\u0438\u0435 \u043d\u0430 \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432, \u0432 \u043c\u0435\u0442\u043e\u0434\u0435 \u043f\u0440\u0435\u0434\u0443\u0441\u043c\u043e\u0442\u0440\u0435\u043d \u0440\u0435\u043a\u0443\u0440\u0441\u0438\u0432\u043d\u044b\u0439 \u0440\u0435\u0442\u0440\u0430\u0439 \u0441 \u0443\u0432\u0435\u043b\u0438\u0447\u0435\u043d\u0438\u0435\u043c \u0438\u043d\u0442\u0435\u0440\u0432\u0430\u043b\u0430 \u043e\u0442\u043f\u0440\u0430\u0432\u043a\u0438 \u0437\u0430\u043f\u0440\u043e\u0441\u043e\u0432.<\/p>\n<\/li>\n<li>\n<p>\u041c\u0435\u0442\u043e\u0434 <code>shouldContinue()<\/code> \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u0442 \u043d\u0435 \u043d\u0430\u0448\u043b\u0438 \u043b\u0438 \u043c\u044b \u043f\u043e\u043b\u043d\u044b\u0439 \u0444\u043b\u0430\u0433.<\/p>\n<\/li>\n<li>\n<p>\u041c\u0435\u0442\u043e\u0434\u044b <code>onKeyByteFound()<\/code> \u0438 <code>onFinished()<\/code> \u043f\u0440\u043e\u0441\u0442\u043e \u0432\u044b\u0432\u043e\u0434\u044f\u0442 \u043d\u0430\u0439\u0434\u0435\u043d\u043d\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430 \u0438 \u043f\u043e\u043b\u043d\u044b\u0439 \u043a\u043b\u044e\u0447 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e.<\/p>\n<\/li>\n<\/ol>\n<p>\u0420\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442\u044b \u0440\u0430\u0431\u043e\u0442\u044b \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u044b:<\/p>\n<figure class=\"full-width\"><img decoding=\"async\" src=\"https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/f5a\/ba9\/31d\/f5aba931de143c9ac585aa46c672c162.png\" width=\"1506\" height=\"98\" sizes=\"auto, (max-width: 780px) 100vw, 50vw\" srcset=\"https:\/\/habrastorage.org\/r\/w780\/getpro\/habr\/upload_files\/f5a\/ba9\/31d\/f5aba931de143c9ac585aa46c672c162.png 780w,&#10;       https:\/\/habrastorage.org\/r\/w1560\/getpro\/habr\/upload_files\/f5a\/ba9\/31d\/f5aba931de143c9ac585aa46c672c162.png 781w\" loading=\"lazy\" decode=\"async\"\/><\/figure>\n<h2>\u0418\u0441\u0442\u043e\u0447\u043d\u0438\u043a\u0438<\/h2>\n<ol>\n<li>\n<p><a href=\"https:\/\/www.cs.cornell.edu\/people\/egs\/615\/rc4_ksaproc.pdf\" rel=\"noopener noreferrer nofollow\">&#171;Weakness of the Key Scheduling Algorithm of RC4&#187;, Fluhrer, Mantin, Shamir<\/a><\/p>\n<\/li>\n<li>\n<p>&#171;Applied Cryptanalysis. Breaking Ciphers in the Real World&#187;, Mark Stamp, Richard M. Low, p. 103 &#8212; 110<\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/kevinliu.me\/posts\/rc4\/\" rel=\"noopener noreferrer nofollow\">&#171;RC4 &#8212; Fluhrer, Mantin, Shamir attack&#187;, Kevin Liu<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/en.wikipedia.org\/wiki\/Fluhrer,_Mantin_and_Shamir_attack\" rel=\"noopener noreferrer nofollow\">Fluhrer, Mantin and Shamir attack, Wikipedia<\/a><\/p>\n<\/li>\n<li>\n<p><a href=\"https:\/\/en.wikipedia.org\/wiki\/RC4\" rel=\"noopener noreferrer nofollow\">RC4, Wikipedia<\/a><\/p>\n<\/li>\n<\/ol>\n<\/div>\n<\/div>\n<\/div>\n<p><!----><!----><\/div>\n<p><!----><!----><br \/> \u0441\u0441\u044b\u043b\u043a\u0430 \u043d\u0430 \u043e\u0440\u0438\u0433\u0438\u043d\u0430\u043b \u0441\u0442\u0430\u0442\u044c\u0438 <a href=\"https:\/\/habr.com\/ru\/articles\/908094\/\"> https:\/\/habr.com\/ru\/articles\/908094\/<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<div><!--[--><!--]--><\/div>\n<div id=\"post-content-body\">\n<div>\n<div class=\"article-formatted-body article-formatted-body article-formatted-body_version-2\">\n<div xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">\n<p>\u041f\u0440\u0438\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e, \u0425\u0430\u0431\u0440! \u0412 \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u0438\u0445 \u043f\u0440\u0435\u0434\u044b\u0434\u0443\u0449\u0438\u0445 \u0441\u0442\u0430\u0442\u044c\u044f\u0445 \u044f \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u043b \u0440\u0435\u0436\u0438\u043c\u044b \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0434\u043b\u044f \u0431\u043b\u043e\u0447\u043d\u044b\u0445 \u0448\u0438\u0444\u0440\u043e\u0432, \u043f\u043e\u0441\u0442\u0435\u043f\u0435\u043d\u043d\u043e \u0441\u0434\u0432\u0438\u0433\u0430\u044f\u0441\u044c \u0432 \u0441\u0442\u043e\u0440\u043e\u043d\u0443 \u0440\u0435\u0436\u0438\u043c\u043e\u0432, \u043f\u0440\u0435\u0432\u0440\u0430\u0449\u0430\u044e\u0449\u0438\u0445 \u0431\u043b\u043e\u0447\u043d\u044b\u0435 \u0448\u0438\u0444\u0440\u044b \u0432 \u043f\u043e\u0442\u043e\u043a\u043e\u0432\u044b\u0435. \u0412 \u043d\u043e\u0432\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u0432 \u0444\u043e\u043a\u0443\u0441\u0435 \u0431\u0443\u0434\u0435\u0442 \u0447\u0438\u0441\u0442\u043e \u043f\u043e\u0442\u043e\u043a\u043e\u0432\u044b\u0439 \u0448\u0438\u0444\u0440 &#8212; RC4. \u042f \u0440\u0430\u0441\u0441\u043a\u0430\u0436\u0443 \u043e \u0441\u0430\u043c\u043e\u043c \u0448\u0438\u0444\u0440\u0435, \u0430 \u0442\u0430\u043a\u0436\u0435 \u043e\u0431 \u0430\u0442\u0430\u043a\u0435 FMS \u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0438 \u0435\u0451 \u0434\u043b\u044f \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0437\u0430\u0434\u0430\u0447\u0438 Oh SNAP \u0441 \u043f\u043b\u0430\u0442\u0444\u043e\u0440\u043c\u044b <a href=\"https:\/\/cryptohack.org\/challenges\/aes\/\" rel=\"noopener noreferrer nofollow\">Cryptohack<\/a>.<\/p>\n<h2>\u0428\u0438\u0444\u0440 RC4<\/h2>\n<p>RC4 &#8212; \u043f\u043e\u0442\u043e\u043a\u043e\u0432\u044b\u0439 \u0448\u0438\u0444\u0440, \u0440\u0430\u0437\u0440\u0430\u0431\u043e\u0442\u0430\u043d\u043d\u044b\u0439 \u0420\u043e\u043d\u043e\u043c \u0420\u0438\u0432\u0435\u0441\u0442\u043e\u043c \u0432 1987 \u0433\u043e\u0434\u0443, \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u044f \u043a\u043e\u0442\u043e\u0440\u043e\u0433\u043e \u0431\u044b\u043b\u0430 \u0441\u043a\u0440\u044b\u0442\u0430 \u043a\u043e\u043c\u043c\u0435\u0440\u0447\u0435\u0441\u043a\u043e\u0439 \u0442\u0430\u0439\u043d\u043e\u0439 \u0434\u043e 1994 \u0433\u043e\u0434\u0430, \u043f\u043e\u0441\u043b\u0435 \u0447\u0435\u0433\u043e \u043e\u043d\u0430 \u0443\u0442\u0435\u043a\u043b\u0430 \u0432 \u0441\u0435\u0442\u044c. \u041a \u043d\u0430\u0447\u0430\u043b\u0443 2000\u0445 \u0433\u043e\u0434\u043e\u0432 \u043e\u043d \u0441\u0442\u0430\u043b \u043e\u0434\u043d\u0438\u043c \u0438\u0437 \u0441\u0430\u043c\u044b\u0445 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u044b\u0445 \u0448\u0438\u0444\u0440\u043e\u0432, \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0445 \u0432 \u043f\u0440\u043e\u0433\u0440\u0430\u043c\u043c\u043d\u043e\u043c \u043e\u0431\u0435\u0441\u043f\u0435\u0447\u0435\u043d\u0438\u0438. \u0422\u0430\u043a\u0430\u044f \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u043e\u0441\u0442\u044c \u0431\u044b\u043b\u0430 \u0432\u043e \u043c\u043d\u043e\u0433\u043e\u043c \u043e\u0431\u0443\u0441\u043b\u043e\u0432\u043b\u0435\u043d\u0430 \u0435\u0433\u043e \u043e\u0447\u0435\u043d\u044c \u043f\u0440\u043e\u0441\u0442\u043e\u0439 \u0441\u0442\u0440\u0443\u043a\u0442\u0443\u0440\u043e\u0439, \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0433\u0438\u0431\u043a\u043e\u0441\u0442\u044c\u044e \u0438 \u0434\u043e\u0441\u0442\u0430\u0442\u043e\u0447\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u043e\u0439 \u0431\u0435\u0437\u043e\u043f\u0430\u0441\u043d\u043e\u0441\u0442\u044c\u044e &#8212; \u0441\u0435\u043a\u0440\u0435\u0442\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0432 ~1700 \u0431\u0438\u0442 \u043f\u0440\u0438 \u043a\u043b\u044e\u0447\u0435 \u0432 8 \u0431\u0430\u0439\u0442.<\/p>\n<p>\u0428\u0438\u0444\u0440 \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0438\u0437 \u0434\u0432\u0443\u0445 \u0447\u0430\u0441\u0442\u0435\u0439: \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 (KSA) \u0438 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 \u0433\u0435\u043d\u0435\u0440\u0430\u0446\u0438\u0438 \u0433\u0430\u043c\u043c\u044b (PRGA). \u041f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438 \u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u0442\u0441\u044f \u0435\u0434\u0438\u043d\u043e\u0436\u0434\u044b \u0434\u043b\u044f \u043f\u043e\u0434\u0433\u043e\u0442\u043e\u0432\u043a\u0438 \u0448\u0438\u0444\u0440\u0430 \u043a \u0440\u0430\u0431\u043e\u0442\u0435. \u041e\u043d\u0430 \u0441\u043e\u0437\u0434\u0430\u0451\u0442 \u0434\u043b\u044f \u0448\u0438\u0444\u0440\u0430 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c \u0432 256 \u0431\u0430\u0439\u0442 \u0438 \u043f\u0435\u0440\u0435\u043c\u0435\u0448\u0438\u0432\u0430\u0435\u0442 \u044d\u0442\u043e \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0432 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0438\u0438 \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u043c \u043a\u043b\u044e\u0447\u043e\u043c \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f.<\/p>\n<blockquote>\n<p>\u0412 \u043e\u0431\u0449\u0435\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0448\u0438\u0444\u0440 RC4 \u043f\u043e\u0434\u0434\u0435\u0440\u0436\u0438\u0432\u0430\u0435\u0442 \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u044b &#171;\u0441\u043b\u043e\u0432\u0430&#187; \u0438 \u0432\u043d\u0443\u0442\u0440\u0435\u043d\u043d\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u0442\u0430\u043a\u0436\u0435 \u043c\u043e\u0436\u0435\u0442 \u0438\u043c\u0435\u0442\u044c \u0440\u0430\u0437\u043b\u0438\u0447\u043d\u044b\u0435 \u0440\u0430\u0437\u043c\u0435\u0440\u044b. \u0412 \u0434\u0430\u043d\u043d\u043e\u0439 \u0441\u0442\u0430\u0442\u044c\u0435 \u044f \u043d\u0435 \u0431\u0443\u0434\u0443 \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u043d\u0430\u0441\u0442\u043e\u043b\u044c\u043a\u043e \u043e\u0431\u043e\u0431\u0449\u0451\u043d\u043d\u044b\u0435 \u0440\u0435\u0430\u043b\u0438\u0437\u0430\u0446\u0438\u0438, \u0440\u0430\u0437\u043c\u0435\u0440 \u0441\u043b\u043e\u0432\u0430 \u0432 \u043d\u0430\u0448\u0435\u0439 \u0437\u0430\u0434\u0430\u0447\u0435 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 \u0431\u0430\u0439\u0442, \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f \u0440\u0430\u0437\u043c\u0435\u0440\u043e\u043c 256, \u0435\u0433\u043e \u0438 \u0431\u0443\u0434\u0435\u043c \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c. <\/p>\n<p>\u0417\u0430 \u0431\u043e\u043b\u0435\u0435 \u043e\u0431\u0449\u0438\u043c \u043e\u043f\u0438\u0441\u0430\u043d\u0438\u0435\u043c \u0448\u0438\u0444\u0440\u0430 \u0438 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0443\u044e\u0449\u0435\u0439 \u0430\u0442\u0430\u043a\u0438 \u0440\u0435\u043a\u043e\u043c\u0435\u043d\u0434\u0443\u044e \u043e\u0437\u043d\u0430\u043a\u043e\u043c\u0438\u0442\u044c\u0441\u044f \u0441 \u043b\u0438\u0442\u0435\u0440\u0430\u0442\u0443\u0440\u043e\u0439 \u0438\u0437 \u0441\u043f\u0438\u0441\u043a\u0430 \u0432 \u043a\u043e\u043d\u0446\u0435 \u0441\u0442\u0430\u0442\u044c\u0438.<\/p>\n<\/blockquote>\n<pre><code class=\"python\">def ksa(key: bytes):   S = [i for i in range(256)]      j = 0   for i in range(256):     j = (j + S[i] + key[i % len(key)]) % 256     S[i], S[j] = S[j], S[i]<\/code><\/pre>\n<p>\u0414\u0430\u043b\u0435\u0435 \u0434\u043b\u044f \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u0431\u0430\u0439\u0442\u0430 \u0433\u0430\u043c\u043c\u044b \u043a\u043b\u044e\u0447\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 PRGA<\/p>\n<pre><code class=\"python\">def prga():   i = 0   j = 0   while True:     i = (i + 1) % 256     j = j + S[i]     S[i], S[j] = S[j], S[i]     yield S[(S[i] + S[j]) % 256]<\/code><\/pre>\n<h2>\u0423\u044f\u0437\u0432\u0438\u043c\u043e\u0441\u0442\u044c \u0432 KSA<\/h2>\n<p>\u0412 2001 \u0433\u043e\u0434\u0443 \u0421\u043a\u043e\u0442\u0442 \u0424\u043b\u044e\u0440\u0435\u0440, \u0418\u0442\u0441\u0438\u043a \u041c\u0430\u043d\u0442\u0438\u043d \u0438 \u0410\u0434\u0438 \u0428\u0430\u043c\u0438\u0440 \u043e\u043f\u0443\u0431\u043b\u0438\u043a\u043e\u0432\u0430\u043b\u0438 \u0441\u0442\u0430\u0442\u044c\u044e \u043f\u043e\u0434 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435\u043c &#171;Weakness in the Key Scheduling Algorithm of RC4&#187;. \u0418\u0437 \u0437\u0430\u0433\u043e\u043b\u043e\u0432\u043a\u0430 \u0441\u0440\u0430\u0437\u0443 \u043f\u043e\u043d\u044f\u0442\u043d\u043e \u0447\u0442\u043e \u0438\u0445 \u0441\u0442\u0430\u0442\u044c\u044f \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0435\u0442 \u043f\u0435\u0440\u0432\u0443\u044e \u0447\u0430\u0441\u0442\u044c \u0448\u0438\u0444\u0440\u0430 &#8212; \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443 KSA. \u042f \u043d\u0435 \u0431\u0443\u0434\u0443 \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u043e \u0440\u0430\u0441\u0441\u043c\u0430\u0442\u0440\u0438\u0432\u0430\u0442\u044c \u0441\u0442\u0430\u0442\u044c\u044e, \u043e\u043f\u0438\u0448\u0443 \u043b\u0438\u0448\u044c \u0435\u0451 \u043e\u0441\u043d\u043e\u0432\u043d\u044b\u0435 \u043c\u043e\u043c\u0435\u043d\u0442\u044b \u0438 \u0441\u0430\u043c\u0443 \u0438\u0434\u0435\u044e \u0430\u0442\u0430\u043a\u0438.<\/p>\n<p>\u0414\u043b\u044f \u043d\u0430\u0447\u0430\u043b\u0430 \u0430\u0432\u0442\u043e\u0440\u044b \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u0443\u044e\u0442 \u043e\u0441\u043b\u0430\u0431\u043b\u0435\u043d\u043d\u0443\u044e \u0432\u0435\u0440\u0441\u0438\u044e \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u044b KSA \u0438 \u0441\u0442\u0440\u043e\u0433\u043e \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442, \u0447\u0442\u043e \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u043a\u043b\u044e\u0447\u0430, \u043f\u0440\u043e\u0445\u043e\u0434\u044f \u0447\u0435\u0440\u0435\u0437 \u044d\u0442\u0443 \u043e\u0441\u043b\u0430\u0431\u043b\u0435\u043d\u043d\u0443\u044e \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0443, \u0441\u043e\u0437\u0434\u0430\u044e\u0442 \u0442\u0430\u043a \u0436\u0435 \u0432\u043f\u043e\u043b\u043d\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u0432 \u0441\u0435\u043a\u0440\u0435\u0442\u043d\u043e\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u0448\u0438\u0444\u0440\u0430 \u0438 \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0432\u0435\u043d\u043d\u043e \u044d\u0442\u043e \u0432\u043b\u0438\u044f\u0435\u0442 \u043d\u0430 \u0448\u0438\u0444\u0440\u043e\u0442\u0435\u043a\u0441\u0442. \u0414\u0440\u0443\u0433\u0438\u043c\u0438 \u0441\u043b\u043e\u0432\u0430\u043c\u0438, \u0435\u0441\u043b\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u043c\u044b\u0439 \u043a\u043b\u044e\u0447 \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u0435\u0442 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u044b\u043c \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u043c, \u0442\u043e \u0438 \u0441\u0435\u043a\u0440\u0435\u0442\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435 \u043f\u043e\u0441\u043b\u0435 \u043e\u0441\u043b\u0430\u0431\u043b\u0435\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u044b KSA \u0442\u0430\u043a\u0436\u0435 \u0431\u0443\u0434\u0435\u0442 \u0443\u0434\u043e\u0432\u043b\u0435\u0442\u0432\u043e\u0440\u044f\u0442\u044c \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u043c \u0443\u0441\u043b\u043e\u0432\u0438\u044f\u043c.<\/p>\n<p>\u0414\u0430\u043b\u0435\u0435 \u043e\u043d\u0438 \u0432\u043d\u043e\u0441\u044f\u0442 \u043f\u043e\u043f\u0440\u0430\u0432\u043a\u0443 \u0434\u043b\u044f \u043d\u0435\u043e\u0441\u043b\u0430\u0431\u043b\u0435\u043d\u043d\u043e\u0439 \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u044b KSA \u0438 \u043f\u043e\u043a\u0430\u0437\u044b\u0432\u0430\u044e\u0442, \u0447\u0442\u043e \u0442\u0435 \u0436\u0435 \u043e\u043f\u0440\u0435\u0434\u0435\u043b\u0451\u043d\u043d\u044b\u0435 \u0448\u0430\u0431\u043b\u043e\u043d\u044b \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0438\u044f \u0431\u0438\u0442 \u0432 \u043a\u043b\u044e\u0447\u0435 \u0431\u0443\u0434\u0443\u0442 \u043f\u0440\u043e\u043d\u0438\u043a\u0430\u0442\u044c \u0432 \u0441\u0435\u043a\u0440\u0435\u0442\u043d\u043e\u0435 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435, \u043e\u0434\u043d\u0430\u043a\u043e \u0442\u0435\u043f\u0435\u0440\u044c \u0441 \u043d\u0435\u043a\u043e\u0442\u043e\u0440\u043e\u0439 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c\u044e. \u0418 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u044d\u0442\u0430 \u0432\u043f\u043e\u043b\u043d\u0435 \u0441\u0443\u0449\u0435\u0441\u0442\u0432\u0435\u043d\u043d\u0430\u044f ().<\/p>\n<p>\u0412 \u043f\u043e\u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0445 \u0441\u0435\u043a\u0446\u0438\u044f\u0445 \u0441\u0442\u0430\u0442\u044c\u0438 \u043e\u043f\u0438\u0441\u0430\u043d\u044b \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0434\u0430\u043d\u043d\u043e\u0439 \u043e\u0441\u043e\u0431\u0435\u043d\u043d\u043e\u0441\u0442\u0438 \u0434\u043b\u044f \u0430\u0442\u0430\u043a\u0438 \u043d\u0430 \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u0435 RC4. \u0412 \u0447\u0430\u0441\u0442\u043d\u043e\u0441\u0442\u0438 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u044e\u0442\u0441\u044f \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u0438 \u0430\u0442\u0430\u043a\u0438 \u0441 \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u0435\u043c \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e\u0433\u043e \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u044e\u0449\u0435\u0433\u043e \u0432\u0435\u043a\u0442\u043e\u0440\u0430 \u0432 \u0441\u043b\u0443\u0447\u0430\u044f\u0445 \u043a\u043e\u0433\u0434\u0430 \u0432\u0435\u043a\u0442\u043e\u0440 \u043f\u0440\u0438\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u0442\u0441\u044f \u043a \u043a\u043b\u044e\u0447\u0443 \u0432 \u043d\u0430\u0447\u0430\u043b\u0435 \u0438\u043b\u0438 \u0432 \u043a\u043e\u043d\u0446\u0435. \u0418\u043c\u0435\u043d\u043d\u043e \u0430\u0442\u0430\u043a\u0443 \u043d\u0430 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0439 \u0438\u043d\u0438\u0446\u0438\u0430\u043b\u0438\u0437\u0438\u0440\u0443\u044e\u0449\u0438\u0439 \u0432\u0435\u043a\u0442\u043e\u0440 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u044c \u0434\u043b\u044f \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0437\u0430\u0434\u0430\u0447\u0438 \u0438 \u0438\u043c\u0435\u043d\u043d\u043e \u044d\u0442\u0430 \u0430\u0442\u0430\u043a\u0430 \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0430 \u043d\u0430\u0437\u0432\u0430\u043d\u0438\u0435 FMS (Fluhrer-Mantin-Shamir) \u0438 \u043e\u0431\u0440\u0435\u043b\u0430 \u043f\u043e\u043f\u0443\u043b\u044f\u0440\u043d\u043e\u0441\u0442\u044c, \u043f\u043e\u0442\u043e\u043c\u0443 \u0447\u0442\u043e \u043e\u043d\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043b\u0430\u0441\u044c \u0434\u043b\u044f <a href=\"https:\/\/www.cs.jhu.edu\/~astubble\/600.412\/s-c-papers\/wireless2.pdf\" rel=\"noopener noreferrer nofollow\">\u0432\u0437\u043b\u043e\u043c\u0430 \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f WiFi \u0441\u0435\u0442\u0435\u0439 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044e\u0449\u0438\u0445 \u0437\u0430\u0449\u0438\u0442\u0443 WEP<\/a>.<\/p>\n<h2>\u0410\u0442\u0430\u043a\u0430 FMS<\/h2>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u0447\u0443\u0442\u044c \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043f\u0440\u043e\u0439\u0434\u0451\u043c\u0441\u044f \u043f\u043e \u043c\u0435\u0445\u0430\u043d\u0438\u043a\u0435 \u0441\u0430\u043c\u043e\u0439 \u0430\u0442\u0430\u043a\u0438. \u0421\u0443\u0442\u044c \u0435\u0451 \u0432 \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u043c:<\/p>\n<ul>\n<li>\n<p>\u0415\u0441\u043b\u0438 IV \u0441\u043e\u0441\u0442\u043e\u0438\u0442 \u0445\u043e\u0442\u044f \u0431\u044b \u0438\u0437 \u0442\u0440\u0451\u0445 \u0431\u0430\u0439\u0442 \u0438 \u0438\u043c\u0435\u0435\u0442 \u0432\u0438\u0434 , \u0433\u0434\u0435  &#8212; \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0439 \u0431\u0430\u0439\u0442; \u0438 \u043c\u044b \u0438\u043c\u0435\u0435\u043c \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0443\u0433\u0430\u0434\u0430\u0442\u044c \u0438\u043b\u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u0433\u0430\u043c\u043c\u044b \u043a\u043b\u044e\u0447\u0430 (\u043c\u044b \u0437\u043d\u0430\u0435\u043c \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043e\u0442\u043a\u0440\u044b\u0442\u043e\u0433\u043e \u0442\u0435\u043a\u0441\u0442\u0430) , \u0442\u043e \u0441 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c\u044e \u043e\u043a\u043e\u043b\u043e 5% \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430  \u043f\u043e \u0444\u043e\u0440\u043c\u0443\u043b\u0435 <\/p>\n<\/li>\n<li>\n<p>\u041f\u043e\u0441\u043b\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u043a\u043b\u044e\u0447\u0430, \u0432\u0442\u043e\u0440\u043e\u0439 \u0431\u0430\u0439\u0442  \u043c\u043e\u0436\u043d\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u0435\u0441\u043b\u0438 IV \u0438\u043c\u0435\u0435\u0442 \u0432\u0438\u0434  \u043f\u043e \u0444\u043e\u0440\u043c\u0443\u043b\u0435 <\/p>\n<\/li>\n<li>\n<p>\u041e\u0431\u043e\u0431\u0449\u0451\u043d\u043d\u0430\u044f \u0444\u043e\u0440\u043c\u0430 IV: , \u0433\u0434\u0435  &#8212; \u043a\u043e\u043b\u0438\u0447\u0435\u0441\u0442\u0432\u043e \u0443\u0436\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u043d\u044b\u0445 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430.<\/p>\n<\/li>\n<li>\n<p>\u041e\u0431\u0449\u0430\u044f \u0444\u043e\u0440\u043c\u0443\u043b\u0430 \u0434\u043b\u044f \u0431\u0430\u0439\u0442\u0430 \u043a\u043b\u044e\u0447\u0430:, \u0433\u0434\u0435  &#8212; \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u0433\u0430\u043c\u043c\u044b \u043a\u043b\u044e\u0447\u0430,  &#8212; \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0438\u043d\u0434\u0435\u043a\u0441\u0430  \u0432 KSA \u043f\u043e\u0441\u043b\u0435  \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439,  &#8212; \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 \u0431\u0430\u0439\u0442\u0430 \u0432 \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0438 \u0448\u0438\u0444\u0440\u0430 \u043f\u043e \u0438\u043d\u0434\u0435\u043a\u0441\u0443  \u043f\u043e\u0441\u043b\u0435  \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439. KSA \u0432 \u0434\u0430\u043d\u043d\u043e\u043c \u0441\u043b\u0443\u0447\u0430\u0435 \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u0442\u0441\u044f \u0441 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u043d\u0438\u0435\u043c \u0443\u0436\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0445 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430. \u0422\u043e \u0435\u0441\u0442\u044c \u0432 KSA \u043c\u044b \u043f\u0435\u0440\u0435\u0434\u0430\u0451\u043c \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435 . \u041d\u0430\u043f\u0440\u0438\u043c\u0435\u0440, \u0434\u043b\u044f \u043f\u043e\u0438\u0441\u043a\u0430 \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u043a\u043b\u044e\u0447\u0430 \u043c\u044b \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u043c 3 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 KSA \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0442\u043e\u043b\u044c\u043a\u043e \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u0439 IV \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043a\u043b\u044e\u0447\u0430. \u0414\u043b\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u043f\u0440\u043e\u0432\u043e\u0434\u0438\u043c \u0443\u0436\u0435 4 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u044f \u0432 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043a\u043b\u044e\u0447\u0430 \u043a\u043e\u043d\u043a\u0430\u0442\u0435\u043d\u0430\u0446\u0438\u044e IV \u0438 \u0443\u0436\u0435 \u0438\u0437\u0432\u0435\u0441\u0442\u043d\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430, \u0438 \u0442. \u0434.<\/p>\n<\/li>\n<\/ul>\n<p>\u0427\u0442\u043e\u0431\u044b \u043f\u043e\u043d\u044f\u0442\u044c \u043e\u0442\u043a\u0443\u0434\u0430 \u0432\u0441\u0451 \u044d\u0442\u043e \u0431\u0435\u0440\u0451\u0442\u0441\u044f \u0440\u0430\u0437\u0431\u0435\u0440\u0451\u043c \u043d\u0435\u0441\u043a\u043e\u043b\u044c\u043a\u043e \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 KSA \u043f\u0440\u0438 IV = (3, 255, X). \u0414\u0435\u0440\u0436\u0438\u0442\u0435 \u0432 \u0443\u043c\u0435, \u0447\u0442\u043e IV \u0434\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0432 \u043d\u0430\u0447\u0430\u043b\u043e \u043a\u043b\u044e\u0447\u0430, \u043f\u043e\u044d\u0442\u043e\u043c\u0443 ,  \u0438  \u0440\u0430\u0432\u043d\u044b ,  \u0438  \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e.<\/p>\n<p>\u0421\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435  \u0438\u0437\u043d\u0430\u0447\u0430\u043b\u044c\u043d\u043e \u0432\u044b\u0433\u043b\u044f\u0434\u0438\u0442 \u0442\u0430\u043a (\u0441\u0432\u0435\u0440\u0445\u0443 \u0438\u043d\u0434\u0435\u043a\u0441, \u0441\u043d\u0438\u0437\u0443 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435)<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0412\u043e \u0432\u0440\u0435\u043c\u044f \u043f\u0435\u0440\u0432\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 , . \u0414\u0430\u043b\u0435\u0435 \u0432  \u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f \u043c\u0435\u0441\u0442\u0430\u043c\u0438 \u044d\u043b\u0435\u043c\u0435\u043d\u0442\u044b \u0441 \u0438\u043d\u0434\u0435\u043a\u0441\u0430\u043c\u0438  \u0438 , \u0441\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u043c \u0441\u043e\u0441\u0442\u043e\u044f\u043d\u0438\u0435<\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0412\u0442\u043e\u0440\u0430\u044f \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f: , <\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0422\u0440\u0435\u0442\u044c\u044f \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f: , <\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u041d\u0430\u043a\u043e\u043d\u0435\u0446, \u0447\u0435\u0442\u0432\u0451\u0440\u0442\u0430\u044f \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u044f: , <\/p>\n<figure class=\"full-width\"><\/figure>\n<p>\u0410 \u0442\u0435\u043f\u0435\u0440\u044c \u0434\u0430\u0432\u0430\u0439\u0442\u0435 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u043c, \u0447\u0442\u043e KSA \u043d\u0430 \u044d\u0442\u043e\u043c \u043e\u0441\u0442\u0430\u043d\u043e\u0432\u0438\u043b\u0430\u0441\u044c. \u0415\u0441\u043b\u0438 \u043c\u044b \u043f\u043e\u043f\u044b\u0442\u0430\u0435\u043c\u0441\u044f \u0441\u0433\u0435\u043d\u0435\u0440\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043e\u0434\u0438\u043d \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0439 \u0433\u0430\u043c\u043c\u044b \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u043e\u0439 PRGA, \u0442\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u043c \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0435<\/p>\n<ol>\n<li>\n<p>, <\/p>\n<\/li>\n<li>\n<p>, <\/p>\n<\/li>\n<li>\n<p>,  \u043c\u0435\u043d\u044f\u044e\u0442\u0441\u044f \u043c\u0435\u0441\u0442\u0430\u043c\u0438, \u043d\u043e \u044d\u0442\u043e \u043d\u0435 \u0432\u043b\u0438\u044f\u0435\u0442 \u043d\u0430 \u0440\u0435\u0437\u0443\u043b\u044c\u0442\u0430\u0442 \u0432\u044b\u0447\u0438\u0441\u043b\u0435\u043d\u0438\u044f \u043f\u0435\u0440\u0432\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430.<\/p>\n<\/li>\n<li>\n<p>\u041f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0439 \u0433\u0430\u043c\u043c\u044b \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0432\u0435\u043d <\/p>\n<\/li>\n<\/ol>\n<p>\u041f\u043e\u043b\u0443\u0447\u0430\u0435\u0442\u0441\u044f, \u0447\u0442\u043e \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0439 \u0433\u0430\u043c\u043c\u044b  \u0441\u0432\u044f\u0437\u0430\u043d \u0441 \u043f\u0435\u0440\u0432\u044b\u043c (\u043d\u0435\u0438\u0437\u0432\u0435\u0441\u0442\u043d\u044b\u043c \u043d\u0430\u043c) \u0431\u0430\u0439\u0442\u043e\u043c \u043a\u043b\u044e\u0447\u0430 \u0444\u043e\u0440\u043c\u0443\u043b\u043e\u0439 , \u0438 \u0435\u0441\u043b\u0438 \u043c\u044b \u0437\u043d\u0430\u0435\u043c \u0447\u0435\u043c\u0443 \u0440\u0430\u0432\u0435\u043d \u044d\u0442\u043e\u0442 \u0431\u0430\u0439\u0442, \u0442\u043e \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043b\u0435\u0433\u043a\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c . \u0422\u043e \u0435\u0441\u0442\u044c \u043c\u044b \u043f\u043e\u043b\u0443\u0447\u0438\u043b\u0438 \u0442\u043e \u0436\u0435 \u043e\u0442\u043d\u043e\u0448\u0435\u043d\u0438\u0435, \u043a\u043e\u0442\u043e\u0440\u043e\u0435 \u044f \u043f\u0440\u0438\u0432\u0451\u043b \u0432 \u043d\u0430\u0447\u0430\u043b\u0435 \u0441\u0435\u043a\u0446\u0438\u0438. \u0424\u043e\u0440\u043c\u0443\u043b\u0443 \u0434\u043b\u044f \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0435\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u043c\u043e\u0436\u043d\u043e \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u0442\u0430\u043a\u0438\u043c \u0436\u0435 \u043e\u0431\u0440\u0430\u0437\u043e\u043c, \u0435\u0441\u043b\u0438 \u0437\u0430\u043c\u0435\u043d\u0438\u0442\u044c IV \u043d\u0430 .<\/p>\n<p>\u0415\u0434\u0438\u043d\u0441\u0442\u0432\u0435\u043d\u043d\u0430\u044f \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430 \u0432 \u0442\u043e\u043c, \u0447\u0442\u043e \u043f\u0440\u043e\u0446\u0435\u0434\u0443\u0440\u0430 KSA \u043d\u0435 \u043e\u0441\u0442\u0430\u043d\u0430\u0432\u043b\u0438\u0432\u0430\u0435\u0442\u0441\u044f \u043f\u043e\u0441\u043b\u0435 4 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439, \u0430 \u043e\u0442\u0440\u0430\u0431\u0430\u0442\u044b\u0432\u0430\u0435\u0442 \u0435\u0449\u0451 252 \u0446\u0438\u043a\u043b\u0430. \u0412 \u043b\u044e\u0431\u043e\u0439 \u0438\u0437 \u044d\u0442\u0438\u0445 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0439 \u0438\u043d\u0434\u0435\u043a\u0441\u044b ,  \u0438  \u043c\u043e\u0433\u0443\u0442 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u044c\u0441\u044f \u0438 \u0442\u043e\u0433\u0434\u0430 \u0444\u043e\u0440\u043c\u0443\u043b\u0430 \u043d\u0435 \u0431\u0443\u0434\u0435\u0442 \u0440\u0430\u0431\u043e\u0442\u0430\u0442\u044c. \u0415\u0441\u043b\u0438 \u043f\u0440\u0435\u0434\u043f\u043e\u043b\u043e\u0436\u0438\u0442\u044c, \u0447\u0442\u043e \u0432 \u043b\u044e\u0431\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u0438\u043d\u0434\u0435\u043a\u0441  \u043f\u0440\u0438\u043d\u0438\u043c\u0430\u0435\u0442 \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435, \u0442\u043e \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0432 \u044d\u0442\u043e\u0439 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f \u043a\u0430\u043a\u043e\u0439-\u0442\u043e \u0438\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 0, 1 \u0438\u043b\u0438 3 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 . \u0421\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0442\u043e\u0433\u043e, \u0447\u0442\u043e \u0437\u0430 \u043d\u0438\u043a\u0430\u043a\u043e\u0439 \u0438\u0437 \u0438\u043d\u0434\u0435\u043a\u0441\u043e\u0432 \u043d\u0435 \u0438\u0437\u043c\u0435\u043d\u0438\u0442\u0441\u044f \u0437\u0430 252 \u0442\u0430\u043a\u0438\u0445 \u0438\u0442\u0435\u0440\u0430\u0446\u0438\u0438 \u0441\u043e\u0441\u0442\u0430\u0432\u043b\u044f\u0435\u0442 . \u041e\u0442\u0441\u044e\u0434\u0430 \u0432\u044b\u0442\u0435\u043a\u0430\u0435\u0442 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0443\u0441\u043f\u0435\u0448\u043d\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430 \u0432 5%.<\/p>\n<p>\u0414\u0430\u0432\u0430\u0439\u0442\u0435 \u043e\u0431\u0440\u0430\u0442\u0438\u043c \u0432\u043d\u0438\u043c\u0430\u043d\u0438\u0435 \u043d\u0430 \u0442\u043e, \u0447\u0442\u043e \u043c\u044b \u0438\u043c\u0435\u0435\u043c 5% \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u043b\u0443\u0447\u0438\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0430, \u0432 95% \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445 \u0441\u043b\u0443\u0447\u0430\u0435\u0432 \u043c\u044b \u0431\u0443\u0434\u0435\u043c \u043f\u043e\u043b\u0443\u0447\u0430\u0442\u044c \u043a\u0430\u043a\u043e\u0435-\u0442\u043e \u0441\u043b\u0443\u0447\u0430\u0439\u043d\u043e\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u0435. \u042d\u0442\u0430 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u0440\u0430\u0441\u043f\u0440\u0435\u0434\u0435\u043b\u0435\u043d\u0430 \u043c\u0435\u0436\u0434\u0443 255 \u0434\u0440\u0443\u0433\u0438\u043c\u0438 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u044b\u043c\u0438 \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u043c\u0438 \u0431\u0430\u0439\u0442\u0430\u043c\u0438. \u0421\u043e\u043e\u0442\u0432\u0435\u0442\u0441\u0442\u0432\u0435\u043d\u043d\u043e, \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u043e\u0441\u0442\u044c \u043f\u043e\u043b\u0443\u0447\u0435\u043d\u0438\u044f \u043a\u0430\u043a\u043e\u0433\u043e-\u043b\u0438\u0431\u043e \u043a\u043e\u043d\u043a\u0440\u0435\u0442\u043d\u043e\u0433\u043e \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u043e\u0433\u043e \u0431\u0430\u0439\u0442\u0430 \u0431\u0443\u0434\u0435\u0442 \u0441\u0438\u043b\u044c\u043d\u043e \u043d\u0438\u0436\u0435 5% (%, \u0435\u0441\u043b\u0438 \u043c\u0435\u043d\u044f \u043d\u0435 \u043f\u043e\u0434\u0432\u043e\u0434\u044f\u0442 \u043c\u043e\u0438 \u0440\u0430\u0441\u0447\u0451\u0442\u044b). \u0418\u043c\u0435\u043d\u043d\u043e \u0442\u0430\u043a\u0438\u043c \u043e\u0431\u0440\u0430\u0437\u043e\u043c \u043c\u044b \u043c\u043e\u0436\u0435\u043c \u043e\u0442\u0434\u0435\u043b\u0438\u0442\u044c \u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0435 \u0437\u043d\u0430\u0447\u0435\u043d\u0438\u044f \u043e\u0442 \u043d\u0435\u043f\u0440\u0430\u0432\u0438\u043b\u044c\u043d\u044b\u0445 &#8212; \u0441\u043e\u0431\u0440\u0430\u0442\u044c \u043a\u0430\u043a \u043c\u043e\u0436\u043d\u043e \u0431\u043e\u043b\u044c\u0448\u0435 \u0432\u0430\u0440\u0438\u0430\u043d\u0442\u043e\u0432 \u0438 \u043d\u0430\u0439\u0442\u0438 \u0442\u043e\u0442, \u043a\u043e\u0442\u043e\u0440\u044b\u0439 \u043f\u043e\u044f\u0432\u043b\u044f\u0435\u0442\u0441\u044f \u0447\u0430\u0449\u0435 \u043e\u0441\u0442\u0430\u043b\u044c\u043d\u044b\u0445.<\/p>\n<h2>\u0420\u0435\u0448\u0435\u043d\u0438\u0435 \u0437\u0430\u0434\u0430\u0447\u0438<\/h2>\n<p>\u0422\u0435\u043f\u0435\u0440\u044c \u043f\u0435\u0440\u0435\u0439\u0434\u0451\u043c \u043a \u0441\u0430\u043c\u043e\u0439 \u0437\u0430\u0434\u0430\u0447\u0435. \u041d\u0430\u043c \u0434\u0430\u043d \u0441\u043b\u0435\u0434\u0443\u044e\u0449\u0438\u0439 \u043a\u043e\u0434<\/p>\n<pre><code class=\"python\">from Crypto.Cipher import ARC4   FLAG = ?   @chal.route('\/oh_snap\/send_cmd\/&lt;ciphertext&gt;\/&lt;nonce&gt;\/') def send_cmd(ciphertext, nonce):     if not ciphertext:         return {\"error\": \"You must specify a ciphertext\"}     if not nonce:         return {\"error\": \"You must specify a nonce\"}      ciphertext = bytes.fromhex(ciphertext)     nonce = bytes.fromhex(nonce)      cipher = ARC4.new(nonce + FLAG.encode())     cmd = cipher.decrypt(ciphertext)     if cmd == b\"ping\":         return {\"msg\": \"Pong!\"}     else:         return {\"error\": f\"Unknown command: {cmd.hex()}\"}<\/code><\/pre>\n<p>\u041d\u0430\u043c \u0434\u0430\u043d\u0430 \u0432\u043e\u0437\u043c\u043e\u0436\u043d\u043e\u0441\u0442\u044c \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u0442\u044c (\u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0447\u0442\u043e \u0437\u0430\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u0442\u044c) \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u0441 \u043f\u043e\u043c\u043e\u0449\u044c\u044e RC4 (ARC4 \u0442\u043e \u0436\u0435 \u0441\u0430\u043c\u043e\u0435 \u0447\u0442\u043e RC4). \u0412 \u043a\u0430\u0447\u0435\u0441\u0442\u0432\u0435 \u043a\u043b\u044e\u0447\u0430 \u0434\u043b\u044f \u0448\u0438\u0444\u0440\u0430 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f \u043f\u0440\u0438\u0441\u043b\u0430\u043d\u043d\u044b\u0439 \u043d\u0430\u043c\u0438 \u043f\u0440\u043e\u0438\u0437\u0432\u043e\u043b\u044c\u043d\u044b\u0439 IV (nonce), \u043a \u043a\u043e\u0442\u043e\u0440\u043e\u043c\u0443 \u0434\u043e\u0431\u0430\u0432\u043b\u0435\u043d \u0444\u043b\u0430\u0433. \u0415\u0441\u043b\u0438 \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u0439 \u0442\u0435\u043a\u0441\u0442 \u043d\u0435 \u0440\u0430\u0432\u0435\u043d <code>ping<\/code>, \u0442\u043e \u0441\u0435\u0440\u0432\u0435\u0440 \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u0435\u0442 \u0441\u043e\u043e\u0431\u0449\u0435\u043d\u0438\u0435 \u043e\u0431 \u043e\u0448\u0438\u0431\u043a\u0435 \u0441 \u0440\u0430\u0441\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u043d\u044b\u043c \u0442\u0435\u043a\u0441\u0442\u043e\u043c.<\/p>\n<p>\u0424\u0430\u043a\u0442\u0438\u0447\u0435\u0441\u043a\u0438 \u043d\u0430\u043c \u0434\u0430\u043d\u0430 \u0438\u0434\u0435\u0430\u043b\u044c\u043d\u0430\u044f \u0441\u0440\u0435\u0434\u0430 \u0434\u043b\u044f \u043f\u0440\u0438\u043c\u0435\u043d\u0435\u043d\u0438\u044f \u0430\u0442\u0430\u043a\u0438 FMS. \u041c\u044b \u0441\u0430\u043c\u0438 \u043c\u043e\u0436\u0435\u043c \u043a\u043e\u043d\u0441\u0442\u0440\u0443\u0438\u0440\u043e\u0432\u0430\u0442\u044c \u043f\u043e\u0434\u0445\u043e\u0434\u044f\u0449\u0438\u0435 \u043d\u0430\u043c IV, \u0430 \u0442\u0430\u043a\u0436\u0435 \u043d\u0430\u043c \u043d\u0435 \u043d\u0443\u0436\u043d\u043e \u0443\u0433\u0430\u0434\u044b\u0432\u0430\u0442\u044c \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u043a\u043b\u044e\u0447\u0435\u0432\u043e\u0439 \u0433\u0430\u043c\u043c\u044b, \u0442.\u043a. \u043c\u044b \u0437\u043d\u0430\u0435\u043c \u0438 \u043e\u0442\u043a\u0440\u044b\u0442\u044b\u0439 \u0438 \u0437\u0430\u043a\u0440\u044b\u0442\u044b\u0439 \u0442\u0435\u043a\u0441\u0442\u044b, \u0430 \u0437\u043d\u0430\u0447\u0438\u0442 \u043c\u043e\u0436\u0435\u043c \u0435\u0433\u043e \u0432\u044b\u0447\u0438\u0441\u043b\u0438\u0442\u044c. \u041e\u0441\u0442\u0430\u043b\u043e\u0441\u044c \u0442\u043e\u043b\u044c\u043a\u043e \u043d\u0430\u043f\u0438\u0441\u0430\u0442\u044c \u043a\u043e\u0434, \u043d\u0435 \u0431\u0443\u0434\u0435\u043c \u0436\u0435 \u043c\u044b \u044d\u0442\u043e \u0434\u0435\u043b\u0430\u0442\u044c \u0432\u0440\u0443\u0447\u043d\u0443\u044e.<\/p>\n<p>\u041a\u043e\u0434 \u0440\u0435\u0448\u0435\u043d\u0438\u044f \u0431\u0443\u0434\u0435\u0442 \u0432\u044b\u0433\u043b\u044f\u0434\u0435\u0442\u044c \u0442\u0430\u043a<\/p>\n<pre><code class=\"python\">import requests import json from time import sleep import os from ptCrypt.Attacks.Symmetric.RC4.FluhrerMantinShamirAttack import FluhrerMantinShamirAttack   baseAddress = \"https:\/\/aes.cryptohack.org\/oh_snap\/send_cmd\"  class Callback(FluhrerMantinShamirAttack.Callback):      def __init__(self):         self.text = os.urandom(16).hex()         self.lastFoundByte = None         self.sleepTime = 1      def applyNonce(self, nonce):         try:             request = f\"{baseAddress}\/{self.text}\/{nonce}\"             response = requests.get(request)                          firstByteCommand = json.loads(response.content)[\"error\"].strip(\"Unknown command: \")[:2]             keyStreamByte = int(firstByteCommand, 16) ^ int(self.text[:2], 16)              return keyStreamByte         except Exception as t:             print(t)             sleep(self.sleepTime)             self.sleepTime = min(60, self.sleepTime * 2)             return self.applyNonce(nonce)                   def shouldContinue(self):         return self.lastFoundByte != b\"}\"      def onKeyByteFound(self, keyByte):         self.lastFoundByte = bytes([keyByte])         print(f\"Found byte: {chr(keyByte)}\")          def onFinished(key):         print(f\"Found key: {key}\")   attack = FluhrerMantinShamirAttack(Callback(), b\"\") attack.run()<\/code><\/pre>\n<p>\u0421\u0430\u043c\u0430 \u0430\u0442\u0430\u043a\u0430 \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u043d\u0430 \u0432\u043d\u0443\u0442\u0440\u0438 \u0431\u0438\u0431\u043b\u0438\u043e\u0442\u0435\u043a\u0438 <a href=\"https:\/\/github.com\/0awawa0\/ptCrypt\" rel=\"noopener noreferrer nofollow\">ptCrypt<\/a> \u043d\u0430\u0447\u0438\u043d\u0430\u044f \u0441 \u0432\u0435\u0440\u0441\u0438\u0438 0.0.14.1. \u041a\u043b\u0430\u0441\u0441 <code>FluhrerMantinShamirAttack<\/code> \u0441\u0430\u043c \u0433\u0435\u043d\u0435\u0440\u0438\u0440\u0443\u0435\u0442 IV \u043d\u0443\u0436\u043d\u043e\u0439 \u0444\u043e\u0440\u043c\u044b \u0438 \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u0442 \u043d\u0430\u0438\u0431\u043e\u043b\u0435\u0435 \u0432\u0435\u0440\u043e\u044f\u0442\u043d\u044b\u0435 \u0431\u0430\u0439\u0442\u044b \u043a\u043b\u044e\u0447\u0430, \u043d\u0435\u043e\u0431\u0445\u043e\u0434\u0438\u043c\u043e \u043f\u043e \u0441\u0443\u0442\u0438 \u0442\u043e\u043b\u044c\u043a\u043e \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u0430\u0442\u044c \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u0435 \u0441 \u0441\u0435\u0440\u0432\u0435\u0440\u043e\u043c \u0438 \u043f\u0430\u0440\u0443 \u043c\u0435\u0442\u043e\u0434\u043e\u0432 \u0434\u043b\u044f \u043a\u043e\u043d\u0442\u0440\u043e\u043b\u044f \u0445\u043e\u0434\u0430 \u0430\u0442\u0430\u043a\u0438.<\/p>\n<p>\u0427\u0443\u0442\u044c \u043f\u043e\u0434\u0440\u043e\u0431\u043d\u0435\u0435 \u043f\u0440\u043e \u043a\u043e\u0434:<\/p>\n<ol>\n<li>\n<p>\u041a\u043b\u0430\u0441\u0441 <code>Callback<\/code> \u0440\u0435\u0430\u043b\u0438\u0437\u043e\u0432\u044b\u0432\u0430\u0435\u0442 \u0438\u043d\u0442\u0435\u0440\u0444\u0435\u0439\u0441 \u043a\u043e\u043b\u0431\u0435\u043a\u0430 <code>FluhrerMantinShamirAttack.Callback<\/code> \u0434\u043b\u044f \u0432\u0437\u0430\u0438\u043c\u043e\u0434\u0435\u0439\u0441\u0442\u0432\u0438\u044f \u0441 \u043a\u043b\u0430\u0441\u0441\u043e\u043c \u0430\u0442\u0430\u043a\u0438.<\/p>\n<\/li>\n<li>\n<p>\u041c\u0435\u0442\u043e\u0434 <code>applyNonce(self, nonce)<\/code> \u043f\u043e\u043b\u0443\u0447\u0430\u0435\u0442 IV \u043d\u0443\u0436\u043d\u043e\u0433\u043e \u0444\u043e\u0440\u043c\u0430\u0442\u0430 \u0438 \u043e\u0442\u043f\u0440\u0430\u0432\u043b\u044f\u0435\u0442 \u043d\u0430 \u0441\u0435\u0440\u0432\u0435\u0440 \u0434\u043b\u044f \u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u0438\u044f, \u0437\u0430\u0442\u0435\u043c \u0438\u0437 \u0437\u0430\u0448\u0438\u0444\u0440\u043e\u0432\u0430\u043d\u043d\u043e\u0433\u043e \u0442\u0435\u043a\u0441\u0442\u0430 \u0432\u044b\u0447\u0438\u0441\u043b\u044f\u0435\u0442 \u043f\u0435\u0440\u0432\u044b\u0439 \u0431\u0430\u0439\u0442 \u0433\u0430\u043c\u043c\u044b \u043a\u043b\u044e\u0447\u0430 \u0438 <\/p>\n<\/li>\n<\/ol>\n<\/div>\n<\/div>\n<\/div>\n<\/div>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[],"tags":[],"class_list":["post-459423","post","type-post","status-publish","format-standard","hentry"],"_links":{"self":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/459423","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=459423"}],"version-history":[{"count":0,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=\/wp\/v2\/posts\/459423\/revisions"}],"wp:attachment":[{"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=459423"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=459423"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/savepearlharbor.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=459423"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}