рд╡реЛрд▓реНрдлреНрд░рд╛рдо рдореИрдердореЗрдЯрд┐рдХрд╛ рдХреЗ рдПрдХ рд▓реЗрдЦ рдореЗрдВ
: рд╣реИрдмрд░рдореИрди рдХрд╛
рдкрд░рд┐рдЪрдп рджреЗрддреЗ рд╣реБрдП ,
8bitjoey рдиреЗ рд╕рдореБрджрд╛рдп рдХреЛ рдЙрддреНрдХреГрд╖реНрдЯ
рд╡реБрд▓реНрдлреНрд░рд╛рдо рдореИрдердореЗрдЯрд┐рдХрд╛ рдЧрдгрд┐рддреАрдп рдкреИрдХреЗрдЬ рд╕реЗ
рдкрд░рд┐рдЪрд┐рдд рдХрд░рд╛рдпрд╛ред
рдЖрдЬ рдореИрдВ рдЗрд╕ рдЙрддреНрдкрд╛рдж рдореЗрдВ рднреНрд░рдордг рдЬрд╛рд░реА рд░рдЦреВрдВрдЧрд╛ред рд╡реНрдпрд╡рд╕рд╛рдп рдХреЛ рдЖрдирдВрдж рдХреЗ рд╕рд╛рде рд╕рдВрдпреЛрдЬрд┐рдд рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП, рд╣рдо рдЗрд╕ рдЙрддреНрдкрд╛рдж рдХрд╛ рдЙрдкрдпреЛрдЧ рдХрд░рдХреЗ рдПрдИрдПрд╕ рдПрд▓реНрдЧреЛрд░рд┐рдереНрдо рдХреЛ рд▓рд╛рдЧреВ рдХрд░рддреЗ рд╣реИрдВред
рд╢реБрд░реВ рдХрд░рдиреЗ рдХреЗ рдмрдЬрд╛рдп
рдпрд╣ рдЖрд▓реЗрдЦ рдЙрди рдЙрдкрдпреЛрдЧрдХрд░реНрддрд╛рдУрдВ рдХреЗ рд▓рд┐рдП рд▓рдХреНрд╖рд┐рдд рд╣реИ рдЬреЛ рдкрд╣рд▓реЗ рд╕реЗ рд╣реА рдХрдо рд╕реЗ рдХрдо рдХреБрдЫ рд╣рдж рддрдХ рдЧрдгрд┐рддрдЬреНрдЮ рд╕реЗ рдкрд░рд┐рдЪрд┐рдд рд╣реИрдВред рдкреНрд░рд╢реНрди рдХреЗ рдкреИрдХреЗрдЬ рдореЗрдВ рдмрд╣реБрдд рд╡рд┐рд╕реНрддреГрдд рдкреНрд░рд▓реЗрдЦрди рд╣реИред рдХрд┐рд╕реА рдлрд╝рдВрдХреНрд╢рди рдХреЗ рдмрд╛рд░реЗ рдореЗрдВ рдорджрдж рдХреЛ рдХреЙрд▓ рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП, рдмрд╕ рдЗрд╕реЗ рдЪреБрдиреЗрдВ рдФрд░ F1 рджрдмрд╛рдПрдВред рдПрдИрдПрд╕ рдПрд▓реНрдЧреЛрд░рд┐рдереНрдо (рдЬрд╛рд╡рд╛рд╕реНрдХреНрд░рд┐рдкреНрдЯ рдЙрджрд╛рд╣рд░рдгреЛрдВ рдХреЗ рд╕рд╛рде) рдХреА рдПрдХ рдЕрдЪреНрдЫреА рд╡реНрдпрд╛рдЦреНрдпрд╛ рд▓реЗрдЦ
рдПрдИрдПрд╕ рд╡рд░реНрдХреНрд╕ рдореЗрдВ рдХреА рдЧрдИ рдереА ред
рдПрдИрдПрд╕ рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди
рд╕рдмрд╕реЗ рдкрд╣рд▓реЗ, рдЪрд▓реЛ рд╡реИрд╢реНрд╡рд┐рдХ рдЪрд░ рдШреЛрд╖рд┐рдд рдХрд░рддреЗ рд╣реИрдВ: рдкреНрд░рддрд┐рд╕реНрдерд╛рдкрди (рдПрд╕-рдмреЙрдХреНрд╕), рд░рд╛рдЙрдВрдб рдХреА рд╕рдВрдЦреНрдпрд╛ (рдПрдирдЖрд░), рдмреНрд▓реЙрдХ рдЖрдХрд╛рд░ (рдПрдирдмреА) рдФрд░ рдХреБрдВрдЬреА рдЖрдХрд╛рд░ (рдПрдирдХреЗ)ред
Needs["FiniteFields`"]; fld = FiniteFields`GF[2, {1, 1, 0, 1, 1, 0, 0, 0, 1}]; Sbox = {99, 124, 119, 123, 242, 107, 111, 197, 48, 1, 103, 43, 254, 215, 171, 118, 202, 130, 201, 125, 250, 89, 71, 240, 173, 212, 162, 175, 156, 164, 114, 192, 183, 253, 147, 38, 54, 63, 247, 204, 52, 165, 229, 241, 113, 216, 49, 21, 4, 199, 35, 195, 24, 150, 5, 154, 7, 18, 128, 226, 235, 39, 178, 117, 9, 131, 44, 26, 27, 110, 90, 160, 82, 59, 214, 179, 41, 227, 47, 132, 83, 209, 0, 237, 32, 252, 177, 91, 106, 203, 190, 57, 74, 76, 88, 207, 208, 239, 170, 251, 67, 77, 51, 133, 69, 249, 2, 127, 80, 60, 159, 168, 81, 163, 64, 143, 146, 157, 56, 245, 188, 182, 218, 33, 16, 255, 243, 210, 205, 12, 19, 236, 95, 151, 68, 23, 196, 167, 126, 61, 100, 93, 25, 115, 96, 129, 79, 220, 34, 42, 144, 136, 70, 238, 184, 20, 222, 94, 11, 219, 224, 50, 58, 10, 73, 6, 36, 92, 194, 211, 172, 98, 145, 149, 228, 121, 231, 200, 55, 109, 141, 213, 78, 169, 108, 86, 244, 234, 101, 122, 174, 8, 186, 120, 37, 46, 28, 166, 180, 198, 232, 221, 116, 31, 75, 189, 139, 138, 112, 62, 181, 102, 72, 3, 246, 14, 97, 53, 87, 185, 134, 193, 29, 158, 225, 248, 152, 17, 105, 217, 142, 148, 155, 30, 135, 233, 206, 85, 40, 223, 140, 161, 137, 13, 191, 230, 66, 104, 65, 153, 45, 15, 176, 84, 187, 22}; Nr = 10; Nb = 4; Nk = 4;
Needs["FiniteFields`"]; fld = FiniteFields`GF[2, {1, 1, 0, 1, 1, 0, 0, 0, 1}]; Sbox = {99, 124, 119, 123, 242, 107, 111, 197, 48, 1, 103, 43, 254, 215, 171, 118, 202, 130, 201, 125, 250, 89, 71, 240, 173, 212, 162, 175, 156, 164, 114, 192, 183, 253, 147, 38, 54, 63, 247, 204, 52, 165, 229, 241, 113, 216, 49, 21, 4, 199, 35, 195, 24, 150, 5, 154, 7, 18, 128, 226, 235, 39, 178, 117, 9, 131, 44, 26, 27, 110, 90, 160, 82, 59, 214, 179, 41, 227, 47, 132, 83, 209, 0, 237, 32, 252, 177, 91, 106, 203, 190, 57, 74, 76, 88, 207, 208, 239, 170, 251, 67, 77, 51, 133, 69, 249, 2, 127, 80, 60, 159, 168, 81, 163, 64, 143, 146, 157, 56, 245, 188, 182, 218, 33, 16, 255, 243, 210, 205, 12, 19, 236, 95, 151, 68, 23, 196, 167, 126, 61, 100, 93, 25, 115, 96, 129, 79, 220, 34, 42, 144, 136, 70, 238, 184, 20, 222, 94, 11, 219, 224, 50, 58, 10, 73, 6, 36, 92, 194, 211, 172, 98, 145, 149, 228, 121, 231, 200, 55, 109, 141, 213, 78, 169, 108, 86, 244, 234, 101, 122, 174, 8, 186, 120, 37, 46, 28, 166, 180, 198, 232, 221, 116, 31, 75, 189, 139, 138, 112, 62, 181, 102, 72, 3, 246, 14, 97, 53, 87, 185, 134, 193, 29, 158, 225, 248, 152, 17, 105, 217, 142, 148, 155, 30, 135, 233, 206, 85, 40, 223, 140, 161, 137, 13, 191, 230, 66, 104, 65, 153, 45, 15, 176, 84, 187, 22}; Nr = 10; Nb = 4; Nk = 4;
рдкрд╣рд▓реА рдкрдВрдХреНрддрд┐ рдкреИрдХреЗрдЬ рдХреЛ
рдкрд░рд┐рдорд┐рдд рдХреНрд╖реЗрддреНрд░реЛрдВ рдХреЗ рд╕рд╛рде рдХрд╛рдо рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП рдЬреЛрдбрд╝рддреА рд╣реИ, рдФрд░ рджреВрд╕рд░реА рдЗрд╕реЗ рдШреЛрд╖рд┐рдд рдХрд░рддреА рд╣реИред {, 1, 1, 0, 1, 1, 0, 0, 1} = 1 + x + x ^ 3 + x ^ 4 + x ^ 8 рдХреНрд╖реЗрддреНрд░ GF (256) рдореЗрдВ
рдПрдХ рдЕрддрд╛рд░реНрдХрд┐рдХ рдмрд╣реБрдкрдж рд╣реИред
рдпрд╣ рдпрд╛рдж рд░рдЦрдиреЗ рдпреЛрдЧреНрдп рд╣реИ рдХрд┐ рдЧрдгрд┐рддрдЬреНрдЮ рдХреЗ рд╕рднреА рдЪрд░ рд╡реИрд╢реНрд╡рд┐рдХ рд╣реИрдВред рдЪрд░ рдХреЛ рд╕реНрдерд╛рдиреАрдп рдмрдирд╛рдиреЗ рдХреЗ рд▓рд┐рдП, рдореЙрдбреНрдпреВрд▓ рдлрд╝рдВрдХреНрд╢рди рдХрд╛ рдЙрдкрдпреЛрдЧ рдХрд┐рдпрд╛ рдЬрд╛рддрд╛ рд╣реИред рдиреАрдЪреЗ рдореБрдЦреНрдп рдлрд╝рдВрдХреНрд╢рди рдХрд╛ рдХреЛрдб рдмрд╛рд░реАрдХреА рд╕реЗ рд╕рдВрдмрдВрдзрд┐рдд рдХрд╛рд░реНрдпреЛрдВ рдХреЗ рд╕рд╛рде рд╣реИред
Rijndael[State_, CipherKey_] := Module[{ExpandedKey, i, tState}, ( tState = State; (* state *) ExpandedKey = KeyExpansion[CipherKey]; (* *) tState = AddRoundKey[tState, ExpandedKey[[1]]]; (* *) For[i = 1, i < Nr, i++, ( tState = RRound[tState, ExpandedKey[[i + 1]]]; (* *) ) ]; tState = FinalRRound[tState, ExpandedKey[[Nr + 1]]]; (* *) Return[tState]; ) ]; Main[] := Module[{}, ( Plaintext = FromDigits["00112233445566778899aabbccddeeff", 16]; Key = FromDigits["000102030405060708090a0b0c0d0e0f", 16]; CipherText = Rijndael[Plaintext, Key]; Print[BaseForm[CipherText, 16]]; Print[CipherText == 16^^69c4e0d86a7b0430d8cdb78070b4c55a]; ) ]; Main[];
Rijndael[State_, CipherKey_] := Module[{ExpandedKey, i, tState}, ( tState = State; (* state *) ExpandedKey = KeyExpansion[CipherKey]; (* *) tState = AddRoundKey[tState, ExpandedKey[[1]]]; (* *) For[i = 1, i < Nr, i++, ( tState = RRound[tState, ExpandedKey[[i + 1]]]; (* *) ) ]; tState = FinalRRound[tState, ExpandedKey[[Nr + 1]]]; (* *) Return[tState]; ) ]; Main[] := Module[{}, ( Plaintext = FromDigits["00112233445566778899aabbccddeeff", 16]; Key = FromDigits["000102030405060708090a0b0c0d0e0f", 16]; CipherText = Rijndael[Plaintext, Key]; Print[BaseForm[CipherText, 16]]; Print[CipherText == 16^^69c4e0d86a7b0430d8cdb78070b4c55a]; ) ]; Main[];
рдЖрджрдд рд╕реЗ рдмрд╛рд╣рд░, рдореИрдВ рдореЙрдбреНрдпреВрд▓ рдХреЗ рдорд╛рдзреНрдпрдо рд╕реЗ рдХреЛрдИ рднреА рдлрд╝рдВрдХреНрд╢рди рд▓рд┐рдЦрддрд╛ рд╣реВрдВ, рдпрд╣рд╛рдВ рддрдХ тАЛтАЛрдХрд┐ рдЦрд╛рд▓реА рдорд╛рдкрджрдВрдбреЛрдВ рдХреЗ рд╕рд╛рде рднреАред рдореБрдЦреНрдп рд╕рдорд╛рд░реЛрд╣ рдореЗрдВ рдирд┐рд░реНрджрд┐рд╖реНрдЯ рд╕рд╛рджрд╛ рдкрд╛рда (рдкреНрд▓реЗрдирдЯреЗрдХреНрд╕реНрдЯ) рдФрд░ рдХреБрдВрдЬреА (рдХреА) рдХреЛрдб рдХрд╛ рдкрд░реАрдХреНрд╖рдг рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП
197 рд╕реЗ рд▓рд┐рдпрд╛ рдЧрдпрд╛ рд╣реИред 16 рд╡реАрдВ рдкреНрд░рдгрд╛рд▓реА рд╕реЗ 10 рд╡реАрдВ рдореЗрдВ рд╕реНрдерд╛рдирд╛рдВрддрд░рдг рджреЛ рддрд░реАрдХреЛрдВ рд╕реЗ рдХрд┐рдпрд╛ рдЬрд╛ рд╕рдХрддрд╛ рд╣реИ: рдореИрдХреНрд░реЛ "16 ^ ^" рдпрд╛ FromDigits рдлрд╝рдВрдХреНрд╢рди рдХреЗ рдорд╛рдзреНрдпрдо рд╕реЗред
рдореИрдереЗрдореЗрдЯрд┐рдХрд╛ рдореЗрдВ рдХреНрд░рд┐рдкреНрдЯреЛрдЧреНрд░рд╛рдлрд╝рд┐рдХ рдПрд▓реНрдЧреЛрд░рд┐рджрдо рд▓рд┐рдЦрддреЗ рд╕рдордп, IntegerDigits рдФрд░ FromDigits рдлрд╝рдВрдХреНрд╢рди рдЕрдХреНрд╕рд░ рдЙрдкрдпреЛрдЧ рдХрд┐рдП рдЬрд╛рддреЗ рд╣реИрдВред рдкрд╣рд▓рд╛ рдирдВрдмрд░ рдХреЛ рдХрд┐рд╕реА рднреА рдЖрдзрд╛рд░ рдкрд░ рдЕрдиреБрд╡рд╛рджрд┐рдд рдХрд░рддрд╛ рд╣реИ, рдФрд░ рджреВрд╕рд░рд╛ рд╡рд┐рдкрд░реАрдд рдХрд╛рд░реНрд░рд╡рд╛рдИ рдХрд░рддрд╛ рд╣реИред
рд░рд╛рдЬреНрдп рд╣рдореЗрд╢рд╛ рдкреВрд░реНрдгрд╛рдВрдХ рдХрд╛ рдкреНрд░рддрд┐рдирд┐рдзрд┐рддреНрд╡ рдХрд░рддрд╛ рд╣реИред рдпрд╣ рдПрд▓реНрдЧреЛрд░рд┐рдереНрдо рдХреЛ рд╕рдордЭрдиреЗ рдХреЗ рдЙрджреНрджреЗрд╢реНрдп рд╕реЗ рд╣реИред
рдиреАрдЪреЗ рдХреБрдВрдЬреА рдкрд░рд┐рдирд┐рдпреЛрдЬрди рдлрд╝рдВрдХреНрд╢рди рдХреЗ рд▓рд┐рдП рдХреЛрдб рд╣реИ:
KeyExpansion[CipherKey_] := Module[{i, j, k, ExpandedKey}, ( ExpandedKey = Array[#*0 &, Nr + 1]; (* Nr + 1 *) ExpandedKey[[1]] = CipherKey; For[i = 1, i <= Nr + 1, i++, ( ExpandedKey[[i]] = IntegerDigits[ExpandedKey[[i]], 2^8, 16]; (* *) ExpandedKey[[i]] = Partition[ExpandedKey[[i]], 4]; (* *) ) ]; (* rcon*) Rcon = Array[{#*0, #*0, #*0, #*0} &, Nr]; Rcon[[1, 1]] = 1; For[i = 2, i <= Nr, i++, ( Rcon[[i, 1]] = Rcon[[i - 1, 1]]*2; If[Rcon[[i, 1]] >= 256, Rcon[[i, 1]] = BitXor[Rcon[[i, 1]], 283]]; ) ]; For[i = 2, i <= Nr + 1, i++, ( ExpandedKey[[i, 1]] = RotateLeft[ExpandedKey[[i - 1, 4]], 1]; (* 1 *) (* *) For[j = 1, j <= 4, j++, ( ExpandedKey[[i, 1, j]] = Sbox[[ExpandedKey[[i, 1, j]] + 1]]; ) ]; (*Xor *) ExpandedKey[[i, 1]] = BitXor[ExpandedKey[[i, 1]], Rcon[[i - 1]], ExpandedKey[[i - 1, 1]]]; (* *) For[k = 2, k <= 4, k++, ( ExpandedKey[[i, k]] = BitXor[ExpandedKey[[i, k - 1]], ExpandedKey[[i - 1, k]]]; ) ]; ) ]; (* Integer*) For[i = 1, i <= Nr + 1, i++, ( ExpandedKey[[i]] = Flatten[ExpandedKey[[i]]]; ExpandedKey[[i]] = FromDigits[ExpandedKey[[i]], 2^8]; ) ]; Return[ExpandedKey]; (* *) ) ];
KeyExpansion[CipherKey_] := Module[{i, j, k, ExpandedKey}, ( ExpandedKey = Array[#*0 &, Nr + 1]; (* Nr + 1 *) ExpandedKey[[1]] = CipherKey; For[i = 1, i <= Nr + 1, i++, ( ExpandedKey[[i]] = IntegerDigits[ExpandedKey[[i]], 2^8, 16]; (* *) ExpandedKey[[i]] = Partition[ExpandedKey[[i]], 4]; (* *) ) ]; (* rcon*) Rcon = Array[{#*0, #*0, #*0, #*0} &, Nr]; Rcon[[1, 1]] = 1; For[i = 2, i <= Nr, i++, ( Rcon[[i, 1]] = Rcon[[i - 1, 1]]*2; If[Rcon[[i, 1]] >= 256, Rcon[[i, 1]] = BitXor[Rcon[[i, 1]], 283]]; ) ]; For[i = 2, i <= Nr + 1, i++, ( ExpandedKey[[i, 1]] = RotateLeft[ExpandedKey[[i - 1, 4]], 1]; (* 1 *) (* *) For[j = 1, j <= 4, j++, ( ExpandedKey[[i, 1, j]] = Sbox[[ExpandedKey[[i, 1, j]] + 1]]; ) ]; (*Xor *) ExpandedKey[[i, 1]] = BitXor[ExpandedKey[[i, 1]], Rcon[[i - 1]], ExpandedKey[[i - 1, 1]]]; (* *) For[k = 2, k <= 4, k++, ( ExpandedKey[[i, k]] = BitXor[ExpandedKey[[i, k - 1]], ExpandedKey[[i - 1, k]]]; ) ]; ) ]; (* Integer*) For[i = 1, i <= Nr + 1, i++, ( ExpandedKey[[i]] = Flatten[ExpandedKey[[i]]]; ExpandedKey[[i]] = FromDigits[ExpandedKey[[i]], 2^8]; ) ]; Return[ExpandedKey]; (* *) ) ];
рдХреЛрдб рдореЗрдВ рдЯрд┐рдкреНрдкрдгреА рдХреА рдЧрдИ рд╣реИ, рдпрджрд┐ рдЖрдкрдХреЗ рдХреЛрдИ рдкреНрд░рд╢реНрди рд╣реИрдВ, рддреЛ рдкреВрдЫреЗрдВред
RRound[State_, Key_] := Module[{i, tState}, ( tState = State; tState = ByteSub[tState]; tState = ShiftRow[tState]; tState = MixColumn[tState]; tState = AddRoundKey[tState, Key]; Return[tState]; ) ]; FinalRRound[State_, Key_] := Module[{i, tState}, ( tState = State; tState = ByteSub[tState]; tState = ShiftRow[tState]; tState = AddRoundKey[tState, Key]; Return[tState]; ) ];
RRound[State_, Key_] := Module[{i, tState}, ( tState = State; tState = ByteSub[tState]; tState = ShiftRow[tState]; tState = MixColumn[tState]; tState = AddRoundKey[tState, Key]; Return[tState]; ) ]; FinalRRound[State_, Key_] := Module[{i, tState}, ( tState = State; tState = ByteSub[tState]; tState = ShiftRow[tState]; tState = AddRoundKey[tState, Key]; Return[tState]; ) ];
рдЪрдХреНрд░реАрдп (рдЧреЛрд▓) рдлрд╝рдВрдХреНрд╢рди рдФрд░ рдЗрд╕ рдХреЛрдб рдореЗрдВ рдкреНрд░рд╕реНрддреБрдд рдЕрдВрддрд┐рдо рдкрд░рд┐рд╡рд░реНрддрди рдХреЗ рдХрд╛рд░реНрдп, рдореБрдЭреЗ рд▓рдЧрддрд╛ рд╣реИ, рд╕реНрдкрд╖реНрдЯреАрдХрд░рдг рдХреА рдЖрд╡рд╢реНрдпрдХрддрд╛ рдирд╣реАрдВ рд╣реИ - рдЙрдиреНрд╣реЗрдВ рдЙрд╕реА рддрд░рд╣ рд╕реЗ рдирд┐рд░реВрдкрд┐рдд рдХрд┐рдпрд╛ рдЬрд╛рддрд╛ рд╣реИ рдЬреИрд╕реЗ рдХрд┐ рдХреВрд▓реНрд╣реЛрдВ 197 рдореЗрдВред
AddRoundKey[State_, RoundKey_] := Module[{tState}, ( tState = BitXor[State, RoundKey]; Return[tState]; ) ];
AddRoundKey[State_, RoundKey_] := Module[{tState}, ( tState = BitXor[State, RoundKey]; Return[tState]; ) ];
рдореБрдЦреНрдп рдЬреЛрдбрд╝ рдлрд╝рдВрдХреНрд╢рди рдмрд╣реБрдд рд╣реА рдЖрджрд┐рдо рд╣реИ: рдореЙрдбреНрдпреВрд▓ 2 рджреНрд╡рд╛рд░рд╛ рдЗрдирдкреБрдЯ рдореВрд▓реНрдп рдФрд░ рдХреБрдВрдЬреА рдХреЛ рдЬреЛрдбрд╝рдирд╛ рдЖрд╡рд╢реНрдпрдХ рд╣реИред рдРрд╕рд╛ рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП, рд╣рдо BitXor рдлрд╝рдВрдХреНрд╢рди рдХрд╛ рдЙрдкрдпреЛрдЧ рдХрд░рддреЗ рд╣реИрдВ, рдЬрд┐рд╕реЗ рдЗрдВрдЯреЗрдЧрд░ рдЗрдирдкреБрдЯ рдХреЛ рдЦрд┐рд▓рд╛рдпрд╛ рдЬрд╛рддрд╛ рд╣реИред
ByteSub[State_] := Module[{i, tState}, ( tState = State; tState = IntegerDigits[tState, 2^8, 16]; For[i = 1, i <= 16, i++, ( tState[[i]] = Sbox[[tState[[i]] + 1]]; ) ]; tState = FromDigits[tState, 2^8]; Return[tState]; ) ];
ByteSub[State_] := Module[{i, tState}, ( tState = State; tState = IntegerDigits[tState, 2^8, 16]; For[i = 1, i <= 16, i++, ( tState[[i]] = Sbox[[tState[[i]] + 1]]; ) ]; tState = FromDigits[tState, 2^8]; Return[tState]; ) ];
SubByte рдлрд╝рдВрдХреНрд╢рди рдореЗрдВ 3 рднрд╛рдЧ рд╣реЛрддреЗ рд╣реИрдВ:
- 16 рдмрд╛рдЗрдЯреНрд╕ рдореЗрдВ рдЗрдВрдЯреАрдЬрд░ рд╡рд┐рднрд╛рдЬрди;
- Sbox рдЪрд░ рд╕реЗ рд╕рдВрдЦреНрдпрд╛рдУрдВ рдХреЗ рд╕рд╛рде рд╕реАрдзреЗ рдЗрдирдкреБрдЯ рдорд╛рдиреЛрдВ рдХреЛ рдмрджрд▓рдирд╛;
- рд╕рдореНтАНрдорд┐рд▓рд┐рдд рдмрд╛рдЗрдЯ рд╡рд╛рдкрд╕ рдЗрдВрдЯреЗрдЧрд░ рдореЗрдВред
ShiftRow[State_] := Module[{tState}, ( tState = State; tState = IntegerDigits[tState, 2^8, 16]; tState = Partition[tState, 4]; tState = Transpose[tState]; tState[[2]] = RotateLeft[tState[[2]], 1]; tState[[3]] = RotateLeft[tState[[3]], 2]; tState[[4]] = RotateLeft[tState[[4]], 3]; tState = Transpose[tState]; tState = Flatten[tState]; tState = FromDigits[tState, 2^8]; Return[tState]; ) ];
ShiftRow[State_] := Module[{tState}, ( tState = State; tState = IntegerDigits[tState, 2^8, 16]; tState = Partition[tState, 4]; tState = Transpose[tState]; tState[[2]] = RotateLeft[tState[[2]], 1]; tState[[3]] = RotateLeft[tState[[3]], 2]; tState[[4]] = RotateLeft[tState[[4]], 3]; tState = Transpose[tState]; tState = Flatten[tState]; tState = FromDigits[tState, 2^8]; Return[tState]; ) ];
ShiftRow рдлрд╝рдВрдХреНрд╢рди рдХреЛрдб рдмрд╣реБрдд рд╕рд░рд▓ рд╣реИред рд▓рд╛рдЗрдиреЛрдВ 1 рд╕реЗ 3 рддрдХ - рдЗрдВрдЯреЗрдЧрд░ рдХрд╛ рдПрдХ рдореИрдЯреНрд░рд┐рдХреНрд╕ рдореЗрдВ рд░реВрдкрд╛рдВрддрд░рдг, рдЕрдЧрд▓реА 3 рдкрдВрдХреНрддрд┐рдпрд╛рдБ рдХреНрд░рдорд╢рдГ 1, 2 рдФрд░ 3 рдмрд╛рдЗрдЯ рдХреЛ рд╕реНрдерд╛рдирд╛рдВрддрд░рд┐рдд рдХрд░рддреА рд╣реИрдВ, рдлрд┐рд░ рдЗрд╕реЗ рдореИрдЯреНрд░рд┐рдХреНрд╕ рд╕реЗ рдЗрдВрдЯреЗрдЧрд░ рдореЗрдВ рд╡рд╛рдкрд╕ рдЯреНрд░рд╛рдВрд╕рд▓реЗрдЯ рдХрд░рддреА рд╣реИрдВред
рдФрд░ рд╕рдмрд╕реЗ рджрд┐рд▓рдЪрд╕реНрдк, рдЧрдгрд┐рдд рдХреЗ рджреГрд╖реНрдЯрд┐рдХреЛрдг рд╕реЗ, рдорд┐рдХреНрд╕рдХреЙрд▓реНрдпреВрдореЗрдВрдЯ рдлрд╝рдВрдХреНрд╢рди, рдЬреЛ рдореИрдВ рдХреЛрдб рдореЗрдВ рд╕реАрдзреЗ рдЯрд┐рдкреНрдкрдгреА рдХрд░реВрдВрдЧрд╛ред рдпрджрд┐ рдЖрдкрдХреЗ рдкрд╛рд╕ рдкреНрд░рд╢реНрди рд╣реИрдВ - рдкреВрдЫреЗрдВред
MixColumn[State_] := Module[{i, j, tState}, ( tState = State; (* Integer *) tState = IntegerDigits[tState, 2^8, 16]; tState = Partition[tState, 4]; tState = Transpose[tState]; (* fips 197*) M = ({ {2, 3, 1, 1}, {1, 2, 3, 1}, {1, 1, 2, 3}, {3, 1, 1, 2} }); (* *) For[i = 1, i <= 4, i++, ( For[j = 1, j <= 4, j++, ( M[[i, j]] = fld[Reverse[IntegerDigits[M[[i, j]], 2, 8]]]; (* Integer *) tState[[i, j]] = fld[Reverse[IntegerDigits[tState[[i, j]], 2, 8]]]; ) ]; ) ]; (* *) tState = M.tState; (* State *) For[i = 1, i <= 4, i++, ( For[j = 1, j <= 4, j++, ( If[tState[[i, j]] == 0, Continue[]]; tState[[i, j]] = FromDigits[Reverse[tState[[i, j]][[1]]], 2]; ) ]; ) ]; (* Integer*) tState = Transpose[tState]; tState = Flatten[tState]; tState = FromDigits[tState, 2^8]; Return[tState]; ) ];
MixColumn[State_] := Module[{i, j, tState}, ( tState = State; (* Integer *) tState = IntegerDigits[tState, 2^8, 16]; tState = Partition[tState, 4]; tState = Transpose[tState]; (* fips 197*) M = ({ {2, 3, 1, 1}, {1, 2, 3, 1}, {1, 1, 2, 3}, {3, 1, 1, 2} }); (* *) For[i = 1, i <= 4, i++, ( For[j = 1, j <= 4, j++, ( M[[i, j]] = fld[Reverse[IntegerDigits[M[[i, j]], 2, 8]]]; (* Integer *) tState[[i, j]] = fld[Reverse[IntegerDigits[tState[[i, j]], 2, 8]]]; ) ]; ) ]; (* *) tState = M.tState; (* State *) For[i = 1, i <= 4, i++, ( For[j = 1, j <= 4, j++, ( If[tState[[i, j]] == 0, Continue[]]; tState[[i, j]] = FromDigits[Reverse[tState[[i, j]][[1]]], 2]; ) ]; ) ]; (* Integer*) tState = Transpose[tState]; tState = Flatten[tState]; tState = FromDigits[tState, 2^8]; Return[tState]; ) ];
рдирд┐рд╖реНрдХрд░реНрд╖
рдЗрд╕ рдкреНрд░рдХрд╛рд░, рдЧрдгрд┐рддрдЬреНрдЮ рдХрд╛ рдЙрдкрдпреЛрдЧ рдХрд░рддреЗ рд╣реБрдП, рдЖрдк рдЖрд╕рд╛рдиреА рд╕реЗ рдПрдиреНрдХреНрд░рд┐рдкреНрд╢рди рдПрд▓реНрдЧреЛрд░рд┐рджрдо рдХреЛ рд▓рд╛рдЧреВ рдХрд░ рд╕рдХрддреЗ рд╣реИрдВ, рдмрд╢рд░реНрддреЗ рдХрд┐ рдЖрдк рдЧрдгрд┐рдд (рдЕрдзрд┐рдХрд╛рдВрд╢ рднрд╛рдЧ
рд╕рдВрдЦреНрдпрд╛ рд╕рд┐рджреНрдзрд╛рдВрдд рдХреЗ рд▓рд┐рдП ) рдХреЛ рдЬрд╛рдирддреЗ рд╣реЛрдВред
рдЕрдВрддрднрд╛рд╖рдг
рдкрд┐рдЫрд▓реЗ рдорд╣реАрдиреЗ рдХреЗ рд▓рд┐рдП рдореИрдВ
рдЛрд╖рд┐ рдЙрддреНрдкрд╛рдж рдХрд╛ рдЙрдкрдпреЛрдЧ рдХрд░рдХреЗ рдкреНрд░реЛрдЧреНрд░рд╛рдорд┐рдВрдЧ рдХрд░ рд░рд╣рд╛ рд╣реВрдВред рд╕рдВрдХреНрд░рдордг рдХрд╛ рдХрд╛рд░рдг рдХреНрд░рд┐рдкреНрдЯреЛрд▓реЙрдЬрд┐рдХрд▓ рдЖрд╡рд╢реНрдпрдХрддрд╛рдУрдВ рдФрд░ рдЙрддреНрдкрд╛рдж рдХреА рдЙрдЪреНрдЪ рд▓рд╛рдЧрдд рдХреЗ рд▓рд┐рдП рдореИрдереЗрдореЗрдЯрд┐рдХрд╛ рдХрд╛ рдЕрдкрд░реНрдпрд╛рдкреНрдд рдкреНрд░рджрд░реНрд╢рди рдерд╛ред рдЕрд╡рд┐рдХрд╕рд┐рдд рдЕрдВрддрд░реНрдирд┐рд╣рд┐рдд рдорджрдж рдХреЗ рдХрд╛рд░рдг рдЧрдгрд┐рддрдЬреНрдЮ рдХреЛ рдЛрд╖рд┐ рдореЗрдВ рдмрджрд▓рдирд╛ рдереЛрдбрд╝рд╛ рдЬрдЯрд┐рд▓ рдерд╛ред рд▓реЗрдХрд┐рди рдХрдИ рджрд┐рдиреЛрдВ рдХреЗ рдмрд╛рдж рдЖрдкрдХреЛ рдЗрд╕рдХреА рдЖрджрдд рдкрдбрд╝ рдЬрд╛рддреА рд╣реИ рдФрд░ рд╕рдм рдХреБрдЫ рд╕рд░рд▓ рд╣реЛ рдЬрд╛рддрд╛ рд╣реИред рдЕрдЬрдЧрд░ рдХреЛ рдЬрд╛рдирдиреЗ рдХреЗ рд▓рд┐рдП рдЖрд╕рд╛рди рдЙрди рд▓реЛрдЧреЛрдВ рдХреЗ рд▓рд┐рдП рд╣реЛрдЧрд╛ рдЬреЛ рдЕрдЬрдЧрд░ рдЬрд╛рдирддреЗ рд╣реИрдВред
рдпрджрд┐ рдЖрдкрдХреЗ рдкрд╛рд╕ рдЧрдгрд┐рддрдЬреНрдЮ рдХреЗ рдмрд╛рд░реЗ рдореЗрдВ рдкреНрд░рд╢реНрди рд╣реИрдВ, рддреЛ рдкреВрдЫреЗрдВ! рдпрджрд┐ рд╕рдВрднрд╡ рд╣реЛ, рддреЛ рдореИрдВ рдЬрд╡рд╛рдм рджреЗрдиреЗ рдХреА рдХреЛрд╢рд┐рд╢ рдХрд░реВрдВрдЧрд╛ред
рд╕рдВрдкреВрд░реНрдг рдПрд▓реНрдЧреЛрд░рд┐рдереНрдо рдХрд╛ рд╕реНрд░реЛрдд рдХреЛрдб
рдпрд╣рд╛рдВ рд╕реЗ рд▓рд┐рдпрд╛ рдЬрд╛ рд╕рдХрддрд╛
рд╣реИ ред