zoukankan      html  css  js  c++  java
  • C写的AES(ECB/PKCS5Padding)

    摘自POLARSSL

     1 #pragma once
     2 
     3 #define AES_ENCRYPT     1
     4 #define AES_DECRYPT     0
     5 
     6 struct aes_context
     7 {
     8     int nr;                     /*!<  number of rounds  */
     9     unsigned int* rk;               /*!<  AES round keys    */
    10     unsigned int buf[68];           /*!<  unaligned data    */
    11 };
    12 
    13 
    14 void aes_setkey_enc( aes_context* ctx, const unsigned char* key, int keysize );
    15 void aes_setkey_dec( aes_context* ctx, const unsigned char* key, int keysize );
    16 void aes_crypt_ecb_update( aes_context* ctx, int mode, const unsigned char input[16], unsigned char output[16] );
    17 unsigned char* aes_crypt_ecb( aes_context* ctx, int mode, const unsigned char* input, int slen, int* dlen );

      1 #include "aes.h"
      2 
      3 
      4 
      5 /*
      6  * Forward S-box
      7  */
      8 static const unsigned char FSb[256] =
      9 {
     10     0x63, 0x7C, 0x77, 0x7B, 0xF2, 0x6B, 0x6F, 0xC5,
     11     0x30, 0x01, 0x67, 0x2B, 0xFE, 0xD7, 0xAB, 0x76,
     12     0xCA, 0x82, 0xC9, 0x7D, 0xFA, 0x59, 0x47, 0xF0,
     13     0xAD, 0xD4, 0xA2, 0xAF, 0x9C, 0xA4, 0x72, 0xC0,
     14     0xB7, 0xFD, 0x93, 0x26, 0x36, 0x3F, 0xF7, 0xCC,
     15     0x34, 0xA5, 0xE5, 0xF1, 0x71, 0xD8, 0x31, 0x15,
     16     0x04, 0xC7, 0x23, 0xC3, 0x18, 0x96, 0x05, 0x9A,
     17     0x07, 0x12, 0x80, 0xE2, 0xEB, 0x27, 0xB2, 0x75,
     18     0x09, 0x83, 0x2C, 0x1A, 0x1B, 0x6E, 0x5A, 0xA0,
     19     0x52, 0x3B, 0xD6, 0xB3, 0x29, 0xE3, 0x2F, 0x84,
     20     0x53, 0xD1, 0x00, 0xED, 0x20, 0xFC, 0xB1, 0x5B,
     21     0x6A, 0xCB, 0xBE, 0x39, 0x4A, 0x4C, 0x58, 0xCF,
     22     0xD0, 0xEF, 0xAA, 0xFB, 0x43, 0x4D, 0x33, 0x85,
     23     0x45, 0xF9, 0x02, 0x7F, 0x50, 0x3C, 0x9F, 0xA8,
     24     0x51, 0xA3, 0x40, 0x8F, 0x92, 0x9D, 0x38, 0xF5,
     25     0xBC, 0xB6, 0xDA, 0x21, 0x10, 0xFF, 0xF3, 0xD2,
     26     0xCD, 0x0C, 0x13, 0xEC, 0x5F, 0x97, 0x44, 0x17,
     27     0xC4, 0xA7, 0x7E, 0x3D, 0x64, 0x5D, 0x19, 0x73,
     28     0x60, 0x81, 0x4F, 0xDC, 0x22, 0x2A, 0x90, 0x88,
     29     0x46, 0xEE, 0xB8, 0x14, 0xDE, 0x5E, 0x0B, 0xDB,
     30     0xE0, 0x32, 0x3A, 0x0A, 0x49, 0x06, 0x24, 0x5C,
     31     0xC2, 0xD3, 0xAC, 0x62, 0x91, 0x95, 0xE4, 0x79,
     32     0xE7, 0xC8, 0x37, 0x6D, 0x8D, 0xD5, 0x4E, 0xA9,
     33     0x6C, 0x56, 0xF4, 0xEA, 0x65, 0x7A, 0xAE, 0x08,
     34     0xBA, 0x78, 0x25, 0x2E, 0x1C, 0xA6, 0xB4, 0xC6,
     35     0xE8, 0xDD, 0x74, 0x1F, 0x4B, 0xBD, 0x8B, 0x8A,
     36     0x70, 0x3E, 0xB5, 0x66, 0x48, 0x03, 0xF6, 0x0E,
     37     0x61, 0x35, 0x57, 0xB9, 0x86, 0xC1, 0x1D, 0x9E,
     38     0xE1, 0xF8, 0x98, 0x11, 0x69, 0xD9, 0x8E, 0x94,
     39     0x9B, 0x1E, 0x87, 0xE9, 0xCE, 0x55, 0x28, 0xDF,
     40     0x8C, 0xA1, 0x89, 0x0D, 0xBF, 0xE6, 0x42, 0x68,
     41     0x41, 0x99, 0x2D, 0x0F, 0xB0, 0x54, 0xBB, 0x16
     42 };
     43 
     44 /*
     45  * Forward tables
     46  */
     47 #define FT 
     48     
     49     V(A5,63,63,C6), V(84,7C,7C,F8), V(99,77,77,EE), V(8D,7B,7B,F6), 
     50     V(0D,F2,F2,FF), V(BD,6B,6B,D6), V(B1,6F,6F,DE), V(54,C5,C5,91), 
     51     V(50,30,30,60), V(03,01,01,02), V(A9,67,67,CE), V(7D,2B,2B,56), 
     52     V(19,FE,FE,E7), V(62,D7,D7,B5), V(E6,AB,AB,4D), V(9A,76,76,EC), 
     53     V(45,CA,CA,8F), V(9D,82,82,1F), V(40,C9,C9,89), V(87,7D,7D,FA), 
     54     V(15,FA,FA,EF), V(EB,59,59,B2), V(C9,47,47,8E), V(0B,F0,F0,FB), 
     55     V(EC,AD,AD,41), V(67,D4,D4,B3), V(FD,A2,A2,5F), V(EA,AF,AF,45), 
     56     V(BF,9C,9C,23), V(F7,A4,A4,53), V(96,72,72,E4), V(5B,C0,C0,9B), 
     57     V(C2,B7,B7,75), V(1C,FD,FD,E1), V(AE,93,93,3D), V(6A,26,26,4C), 
     58     V(5A,36,36,6C), V(41,3F,3F,7E), V(02,F7,F7,F5), V(4F,CC,CC,83), 
     59     V(5C,34,34,68), V(F4,A5,A5,51), V(34,E5,E5,D1), V(08,F1,F1,F9), 
     60     V(93,71,71,E2), V(73,D8,D8,AB), V(53,31,31,62), V(3F,15,15,2A), 
     61     V(0C,04,04,08), V(52,C7,C7,95), V(65,23,23,46), V(5E,C3,C3,9D), 
     62     V(28,18,18,30), V(A1,96,96,37), V(0F,05,05,0A), V(B5,9A,9A,2F), 
     63     V(09,07,07,0E), V(36,12,12,24), V(9B,80,80,1B), V(3D,E2,E2,DF), 
     64     V(26,EB,EB,CD), V(69,27,27,4E), V(CD,B2,B2,7F), V(9F,75,75,EA), 
     65     V(1B,09,09,12), V(9E,83,83,1D), V(74,2C,2C,58), V(2E,1A,1A,34), 
     66     V(2D,1B,1B,36), V(B2,6E,6E,DC), V(EE,5A,5A,B4), V(FB,A0,A0,5B), 
     67     V(F6,52,52,A4), V(4D,3B,3B,76), V(61,D6,D6,B7), V(CE,B3,B3,7D), 
     68     V(7B,29,29,52), V(3E,E3,E3,DD), V(71,2F,2F,5E), V(97,84,84,13), 
     69     V(F5,53,53,A6), V(68,D1,D1,B9), V(00,00,00,00), V(2C,ED,ED,C1), 
     70     V(60,20,20,40), V(1F,FC,FC,E3), V(C8,B1,B1,79), V(ED,5B,5B,B6), 
     71     V(BE,6A,6A,D4), V(46,CB,CB,8D), V(D9,BE,BE,67), V(4B,39,39,72), 
     72     V(DE,4A,4A,94), V(D4,4C,4C,98), V(E8,58,58,B0), V(4A,CF,CF,85), 
     73     V(6B,D0,D0,BB), V(2A,EF,EF,C5), V(E5,AA,AA,4F), V(16,FB,FB,ED), 
     74     V(C5,43,43,86), V(D7,4D,4D,9A), V(55,33,33,66), V(94,85,85,11), 
     75     V(CF,45,45,8A), V(10,F9,F9,E9), V(06,02,02,04), V(81,7F,7F,FE), 
     76     V(F0,50,50,A0), V(44,3C,3C,78), V(BA,9F,9F,25), V(E3,A8,A8,4B), 
     77     V(F3,51,51,A2), V(FE,A3,A3,5D), V(C0,40,40,80), V(8A,8F,8F,05), 
     78     V(AD,92,92,3F), V(BC,9D,9D,21), V(48,38,38,70), V(04,F5,F5,F1), 
     79     V(DF,BC,BC,63), V(C1,B6,B6,77), V(75,DA,DA,AF), V(63,21,21,42), 
     80     V(30,10,10,20), V(1A,FF,FF,E5), V(0E,F3,F3,FD), V(6D,D2,D2,BF), 
     81     V(4C,CD,CD,81), V(14,0C,0C,18), V(35,13,13,26), V(2F,EC,EC,C3), 
     82     V(E1,5F,5F,BE), V(A2,97,97,35), V(CC,44,44,88), V(39,17,17,2E), 
     83     V(57,C4,C4,93), V(F2,A7,A7,55), V(82,7E,7E,FC), V(47,3D,3D,7A), 
     84     V(AC,64,64,C8), V(E7,5D,5D,BA), V(2B,19,19,32), V(95,73,73,E6), 
     85     V(A0,60,60,C0), V(98,81,81,19), V(D1,4F,4F,9E), V(7F,DC,DC,A3), 
     86     V(66,22,22,44), V(7E,2A,2A,54), V(AB,90,90,3B), V(83,88,88,0B), 
     87     V(CA,46,46,8C), V(29,EE,EE,C7), V(D3,B8,B8,6B), V(3C,14,14,28), 
     88     V(79,DE,DE,A7), V(E2,5E,5E,BC), V(1D,0B,0B,16), V(76,DB,DB,AD), 
     89     V(3B,E0,E0,DB), V(56,32,32,64), V(4E,3A,3A,74), V(1E,0A,0A,14), 
     90     V(DB,49,49,92), V(0A,06,06,0C), V(6C,24,24,48), V(E4,5C,5C,B8), 
     91     V(5D,C2,C2,9F), V(6E,D3,D3,BD), V(EF,AC,AC,43), V(A6,62,62,C4), 
     92     V(A8,91,91,39), V(A4,95,95,31), V(37,E4,E4,D3), V(8B,79,79,F2), 
     93     V(32,E7,E7,D5), V(43,C8,C8,8B), V(59,37,37,6E), V(B7,6D,6D,DA), 
     94     V(8C,8D,8D,01), V(64,D5,D5,B1), V(D2,4E,4E,9C), V(E0,A9,A9,49), 
     95     V(B4,6C,6C,D8), V(FA,56,56,AC), V(07,F4,F4,F3), V(25,EA,EA,CF), 
     96     V(AF,65,65,CA), V(8E,7A,7A,F4), V(E9,AE,AE,47), V(18,08,08,10), 
     97     V(D5,BA,BA,6F), V(88,78,78,F0), V(6F,25,25,4A), V(72,2E,2E,5C), 
     98     V(24,1C,1C,38), V(F1,A6,A6,57), V(C7,B4,B4,73), V(51,C6,C6,97), 
     99     V(23,E8,E8,CB), V(7C,DD,DD,A1), V(9C,74,74,E8), V(21,1F,1F,3E), 
    100     V(DD,4B,4B,96), V(DC,BD,BD,61), V(86,8B,8B,0D), V(85,8A,8A,0F), 
    101     V(90,70,70,E0), V(42,3E,3E,7C), V(C4,B5,B5,71), V(AA,66,66,CC), 
    102     V(D8,48,48,90), V(05,03,03,06), V(01,F6,F6,F7), V(12,0E,0E,1C), 
    103     V(A3,61,61,C2), V(5F,35,35,6A), V(F9,57,57,AE), V(D0,B9,B9,69), 
    104     V(91,86,86,17), V(58,C1,C1,99), V(27,1D,1D,3A), V(B9,9E,9E,27), 
    105     V(38,E1,E1,D9), V(13,F8,F8,EB), V(B3,98,98,2B), V(33,11,11,22), 
    106     V(BB,69,69,D2), V(70,D9,D9,A9), V(89,8E,8E,07), V(A7,94,94,33), 
    107     V(B6,9B,9B,2D), V(22,1E,1E,3C), V(92,87,87,15), V(20,E9,E9,C9), 
    108     V(49,CE,CE,87), V(FF,55,55,AA), V(78,28,28,50), V(7A,DF,DF,A5), 
    109     V(8F,8C,8C,03), V(F8,A1,A1,59), V(80,89,89,09), V(17,0D,0D,1A), 
    110     V(DA,BF,BF,65), V(31,E6,E6,D7), V(C6,42,42,84), V(B8,68,68,D0), 
    111     V(C3,41,41,82), V(B0,99,99,29), V(77,2D,2D,5A), V(11,0F,0F,1E), 
    112     V(CB,B0,B0,7B), V(FC,54,54,A8), V(D6,BB,BB,6D), V(3A,16,16,2C)
    113 
    114 #define V(a,b,c,d) 0x##a##b##c##d
    115 static const unsigned int FT0[256] = { FT };
    116 #undef V
    117 
    118 #define V(a,b,c,d) 0x##b##c##d##a
    119 static const unsigned int FT1[256] = { FT };
    120 #undef V
    121 
    122 #define V(a,b,c,d) 0x##c##d##a##b
    123 static const unsigned int FT2[256] = { FT };
    124 #undef V
    125 
    126 #define V(a,b,c,d) 0x##d##a##b##c
    127 static const unsigned int FT3[256] = { FT };
    128 #undef V
    129 
    130 #undef FT
    131 
    132 /*
    133  * Reverse S-box
    134  */
    135 static const unsigned char RSb[256] =
    136 {
    137     0x52, 0x09, 0x6A, 0xD5, 0x30, 0x36, 0xA5, 0x38,
    138     0xBF, 0x40, 0xA3, 0x9E, 0x81, 0xF3, 0xD7, 0xFB,
    139     0x7C, 0xE3, 0x39, 0x82, 0x9B, 0x2F, 0xFF, 0x87,
    140     0x34, 0x8E, 0x43, 0x44, 0xC4, 0xDE, 0xE9, 0xCB,
    141     0x54, 0x7B, 0x94, 0x32, 0xA6, 0xC2, 0x23, 0x3D,
    142     0xEE, 0x4C, 0x95, 0x0B, 0x42, 0xFA, 0xC3, 0x4E,
    143     0x08, 0x2E, 0xA1, 0x66, 0x28, 0xD9, 0x24, 0xB2,
    144     0x76, 0x5B, 0xA2, 0x49, 0x6D, 0x8B, 0xD1, 0x25,
    145     0x72, 0xF8, 0xF6, 0x64, 0x86, 0x68, 0x98, 0x16,
    146     0xD4, 0xA4, 0x5C, 0xCC, 0x5D, 0x65, 0xB6, 0x92,
    147     0x6C, 0x70, 0x48, 0x50, 0xFD, 0xED, 0xB9, 0xDA,
    148     0x5E, 0x15, 0x46, 0x57, 0xA7, 0x8D, 0x9D, 0x84,
    149     0x90, 0xD8, 0xAB, 0x00, 0x8C, 0xBC, 0xD3, 0x0A,
    150     0xF7, 0xE4, 0x58, 0x05, 0xB8, 0xB3, 0x45, 0x06,
    151     0xD0, 0x2C, 0x1E, 0x8F, 0xCA, 0x3F, 0x0F, 0x02,
    152     0xC1, 0xAF, 0xBD, 0x03, 0x01, 0x13, 0x8A, 0x6B,
    153     0x3A, 0x91, 0x11, 0x41, 0x4F, 0x67, 0xDC, 0xEA,
    154     0x97, 0xF2, 0xCF, 0xCE, 0xF0, 0xB4, 0xE6, 0x73,
    155     0x96, 0xAC, 0x74, 0x22, 0xE7, 0xAD, 0x35, 0x85,
    156     0xE2, 0xF9, 0x37, 0xE8, 0x1C, 0x75, 0xDF, 0x6E,
    157     0x47, 0xF1, 0x1A, 0x71, 0x1D, 0x29, 0xC5, 0x89,
    158     0x6F, 0xB7, 0x62, 0x0E, 0xAA, 0x18, 0xBE, 0x1B,
    159     0xFC, 0x56, 0x3E, 0x4B, 0xC6, 0xD2, 0x79, 0x20,
    160     0x9A, 0xDB, 0xC0, 0xFE, 0x78, 0xCD, 0x5A, 0xF4,
    161     0x1F, 0xDD, 0xA8, 0x33, 0x88, 0x07, 0xC7, 0x31,
    162     0xB1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xEC, 0x5F,
    163     0x60, 0x51, 0x7F, 0xA9, 0x19, 0xB5, 0x4A, 0x0D,
    164     0x2D, 0xE5, 0x7A, 0x9F, 0x93, 0xC9, 0x9C, 0xEF,
    165     0xA0, 0xE0, 0x3B, 0x4D, 0xAE, 0x2A, 0xF5, 0xB0,
    166     0xC8, 0xEB, 0xBB, 0x3C, 0x83, 0x53, 0x99, 0x61,
    167     0x17, 0x2B, 0x04, 0x7E, 0xBA, 0x77, 0xD6, 0x26,
    168     0xE1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0C, 0x7D
    169 };
    170 
    171 /*
    172  * Reverse tables
    173  */
    174 #define RT 
    175     
    176     V(50,A7,F4,51), V(53,65,41,7E), V(C3,A4,17,1A), V(96,5E,27,3A), 
    177     V(CB,6B,AB,3B), V(F1,45,9D,1F), V(AB,58,FA,AC), V(93,03,E3,4B), 
    178     V(55,FA,30,20), V(F6,6D,76,AD), V(91,76,CC,88), V(25,4C,02,F5), 
    179     V(FC,D7,E5,4F), V(D7,CB,2A,C5), V(80,44,35,26), V(8F,A3,62,B5), 
    180     V(49,5A,B1,DE), V(67,1B,BA,25), V(98,0E,EA,45), V(E1,C0,FE,5D), 
    181     V(02,75,2F,C3), V(12,F0,4C,81), V(A3,97,46,8D), V(C6,F9,D3,6B), 
    182     V(E7,5F,8F,03), V(95,9C,92,15), V(EB,7A,6D,BF), V(DA,59,52,95), 
    183     V(2D,83,BE,D4), V(D3,21,74,58), V(29,69,E0,49), V(44,C8,C9,8E), 
    184     V(6A,89,C2,75), V(78,79,8E,F4), V(6B,3E,58,99), V(DD,71,B9,27), 
    185     V(B6,4F,E1,BE), V(17,AD,88,F0), V(66,AC,20,C9), V(B4,3A,CE,7D), 
    186     V(18,4A,DF,63), V(82,31,1A,E5), V(60,33,51,97), V(45,7F,53,62), 
    187     V(E0,77,64,B1), V(84,AE,6B,BB), V(1C,A0,81,FE), V(94,2B,08,F9), 
    188     V(58,68,48,70), V(19,FD,45,8F), V(87,6C,DE,94), V(B7,F8,7B,52), 
    189     V(23,D3,73,AB), V(E2,02,4B,72), V(57,8F,1F,E3), V(2A,AB,55,66), 
    190     V(07,28,EB,B2), V(03,C2,B5,2F), V(9A,7B,C5,86), V(A5,08,37,D3), 
    191     V(F2,87,28,30), V(B2,A5,BF,23), V(BA,6A,03,02), V(5C,82,16,ED), 
    192     V(2B,1C,CF,8A), V(92,B4,79,A7), V(F0,F2,07,F3), V(A1,E2,69,4E), 
    193     V(CD,F4,DA,65), V(D5,BE,05,06), V(1F,62,34,D1), V(8A,FE,A6,C4), 
    194     V(9D,53,2E,34), V(A0,55,F3,A2), V(32,E1,8A,05), V(75,EB,F6,A4), 
    195     V(39,EC,83,0B), V(AA,EF,60,40), V(06,9F,71,5E), V(51,10,6E,BD), 
    196     V(F9,8A,21,3E), V(3D,06,DD,96), V(AE,05,3E,DD), V(46,BD,E6,4D), 
    197     V(B5,8D,54,91), V(05,5D,C4,71), V(6F,D4,06,04), V(FF,15,50,60), 
    198     V(24,FB,98,19), V(97,E9,BD,D6), V(CC,43,40,89), V(77,9E,D9,67), 
    199     V(BD,42,E8,B0), V(88,8B,89,07), V(38,5B,19,E7), V(DB,EE,C8,79), 
    200     V(47,0A,7C,A1), V(E9,0F,42,7C), V(C9,1E,84,F8), V(00,00,00,00), 
    201     V(83,86,80,09), V(48,ED,2B,32), V(AC,70,11,1E), V(4E,72,5A,6C), 
    202     V(FB,FF,0E,FD), V(56,38,85,0F), V(1E,D5,AE,3D), V(27,39,2D,36), 
    203     V(64,D9,0F,0A), V(21,A6,5C,68), V(D1,54,5B,9B), V(3A,2E,36,24), 
    204     V(B1,67,0A,0C), V(0F,E7,57,93), V(D2,96,EE,B4), V(9E,91,9B,1B), 
    205     V(4F,C5,C0,80), V(A2,20,DC,61), V(69,4B,77,5A), V(16,1A,12,1C), 
    206     V(0A,BA,93,E2), V(E5,2A,A0,C0), V(43,E0,22,3C), V(1D,17,1B,12), 
    207     V(0B,0D,09,0E), V(AD,C7,8B,F2), V(B9,A8,B6,2D), V(C8,A9,1E,14), 
    208     V(85,19,F1,57), V(4C,07,75,AF), V(BB,DD,99,EE), V(FD,60,7F,A3), 
    209     V(9F,26,01,F7), V(BC,F5,72,5C), V(C5,3B,66,44), V(34,7E,FB,5B), 
    210     V(76,29,43,8B), V(DC,C6,23,CB), V(68,FC,ED,B6), V(63,F1,E4,B8), 
    211     V(CA,DC,31,D7), V(10,85,63,42), V(40,22,97,13), V(20,11,C6,84), 
    212     V(7D,24,4A,85), V(F8,3D,BB,D2), V(11,32,F9,AE), V(6D,A1,29,C7), 
    213     V(4B,2F,9E,1D), V(F3,30,B2,DC), V(EC,52,86,0D), V(D0,E3,C1,77), 
    214     V(6C,16,B3,2B), V(99,B9,70,A9), V(FA,48,94,11), V(22,64,E9,47), 
    215     V(C4,8C,FC,A8), V(1A,3F,F0,A0), V(D8,2C,7D,56), V(EF,90,33,22), 
    216     V(C7,4E,49,87), V(C1,D1,38,D9), V(FE,A2,CA,8C), V(36,0B,D4,98), 
    217     V(CF,81,F5,A6), V(28,DE,7A,A5), V(26,8E,B7,DA), V(A4,BF,AD,3F), 
    218     V(E4,9D,3A,2C), V(0D,92,78,50), V(9B,CC,5F,6A), V(62,46,7E,54), 
    219     V(C2,13,8D,F6), V(E8,B8,D8,90), V(5E,F7,39,2E), V(F5,AF,C3,82), 
    220     V(BE,80,5D,9F), V(7C,93,D0,69), V(A9,2D,D5,6F), V(B3,12,25,CF), 
    221     V(3B,99,AC,C8), V(A7,7D,18,10), V(6E,63,9C,E8), V(7B,BB,3B,DB), 
    222     V(09,78,26,CD), V(F4,18,59,6E), V(01,B7,9A,EC), V(A8,9A,4F,83), 
    223     V(65,6E,95,E6), V(7E,E6,FF,AA), V(08,CF,BC,21), V(E6,E8,15,EF), 
    224     V(D9,9B,E7,BA), V(CE,36,6F,4A), V(D4,09,9F,EA), V(D6,7C,B0,29), 
    225     V(AF,B2,A4,31), V(31,23,3F,2A), V(30,94,A5,C6), V(C0,66,A2,35), 
    226     V(37,BC,4E,74), V(A6,CA,82,FC), V(B0,D0,90,E0), V(15,D8,A7,33), 
    227     V(4A,98,04,F1), V(F7,DA,EC,41), V(0E,50,CD,7F), V(2F,F6,91,17), 
    228     V(8D,D6,4D,76), V(4D,B0,EF,43), V(54,4D,AA,CC), V(DF,04,96,E4), 
    229     V(E3,B5,D1,9E), V(1B,88,6A,4C), V(B8,1F,2C,C1), V(7F,51,65,46), 
    230     V(04,EA,5E,9D), V(5D,35,8C,01), V(73,74,87,FA), V(2E,41,0B,FB), 
    231     V(5A,1D,67,B3), V(52,D2,DB,92), V(33,56,10,E9), V(13,47,D6,6D), 
    232     V(8C,61,D7,9A), V(7A,0C,A1,37), V(8E,14,F8,59), V(89,3C,13,EB), 
    233     V(EE,27,A9,CE), V(35,C9,61,B7), V(ED,E5,1C,E1), V(3C,B1,47,7A), 
    234     V(59,DF,D2,9C), V(3F,73,F2,55), V(79,CE,14,18), V(BF,37,C7,73), 
    235     V(EA,CD,F7,53), V(5B,AA,FD,5F), V(14,6F,3D,DF), V(86,DB,44,78), 
    236     V(81,F3,AF,CA), V(3E,C4,68,B9), V(2C,34,24,38), V(5F,40,A3,C2), 
    237     V(72,C3,1D,16), V(0C,25,E2,BC), V(8B,49,3C,28), V(41,95,0D,FF), 
    238     V(71,01,A8,39), V(DE,B3,0C,08), V(9C,E4,B4,D8), V(90,C1,56,64), 
    239     V(61,84,CB,7B), V(70,B6,32,D5), V(74,5C,6C,48), V(42,57,B8,D0)
    240 
    241 #define V(a,b,c,d) 0x##a##b##c##d
    242 static const unsigned int RT0[256] = { RT };
    243 #undef V
    244 
    245 #define V(a,b,c,d) 0x##b##c##d##a
    246 static const unsigned int RT1[256] = { RT };
    247 #undef V
    248 
    249 #define V(a,b,c,d) 0x##c##d##a##b
    250 static const unsigned int RT2[256] = { RT };
    251 #undef V
    252 
    253 #define V(a,b,c,d) 0x##d##a##b##c
    254 static const unsigned int RT3[256] = { RT };
    255 #undef V
    256 
    257 #undef RT
    258 
    259 /*
    260  * Round constants
    261  */
    262 static const unsigned int RCON[10] =
    263 {
    264     0x00000001, 0x00000002, 0x00000004, 0x00000008,
    265     0x00000010, 0x00000020, 0x00000040, 0x00000080,
    266     0x0000001B, 0x00000036
    267 };
    268 
    269 #define AES_FROUND(X0,X1,X2,X3,Y0,Y1,Y2,Y3)     
    270     {                                               
    271         X0 = *RK++ ^ FT0[ ( Y0       ) & 0xFF ] ^   
    272              FT1[ ( Y1 >>  8 ) & 0xFF ] ^   
    273              FT2[ ( Y2 >> 16 ) & 0xFF ] ^   
    274              FT3[ ( Y3 >> 24 ) & 0xFF ];    
    275         
    276         X1 = *RK++ ^ FT0[ ( Y1       ) & 0xFF ] ^   
    277              FT1[ ( Y2 >>  8 ) & 0xFF ] ^   
    278              FT2[ ( Y3 >> 16 ) & 0xFF ] ^   
    279              FT3[ ( Y0 >> 24 ) & 0xFF ];    
    280         
    281         X2 = *RK++ ^ FT0[ ( Y2       ) & 0xFF ] ^   
    282              FT1[ ( Y3 >>  8 ) & 0xFF ] ^   
    283              FT2[ ( Y0 >> 16 ) & 0xFF ] ^   
    284              FT3[ ( Y1 >> 24 ) & 0xFF ];    
    285         
    286         X3 = *RK++ ^ FT0[ ( Y3       ) & 0xFF ] ^   
    287              FT1[ ( Y0 >>  8 ) & 0xFF ] ^   
    288              FT2[ ( Y1 >> 16 ) & 0xFF ] ^   
    289              FT3[ ( Y2 >> 24 ) & 0xFF ];    
    290     }
    291 
    292 #define AES_RROUND(X0,X1,X2,X3,Y0,Y1,Y2,Y3)     
    293     {                                               
    294         X0 = *RK++ ^ RT0[ ( Y0       ) & 0xFF ] ^   
    295              RT1[ ( Y3 >>  8 ) & 0xFF ] ^   
    296              RT2[ ( Y2 >> 16 ) & 0xFF ] ^   
    297              RT3[ ( Y1 >> 24 ) & 0xFF ];    
    298         
    299         X1 = *RK++ ^ RT0[ ( Y1       ) & 0xFF ] ^   
    300              RT1[ ( Y0 >>  8 ) & 0xFF ] ^   
    301              RT2[ ( Y3 >> 16 ) & 0xFF ] ^   
    302              RT3[ ( Y2 >> 24 ) & 0xFF ];    
    303         
    304         X2 = *RK++ ^ RT0[ ( Y2       ) & 0xFF ] ^   
    305              RT1[ ( Y1 >>  8 ) & 0xFF ] ^   
    306              RT2[ ( Y0 >> 16 ) & 0xFF ] ^   
    307              RT3[ ( Y3 >> 24 ) & 0xFF ];    
    308         
    309         X3 = *RK++ ^ RT0[ ( Y3       ) & 0xFF ] ^   
    310              RT1[ ( Y2 >>  8 ) & 0xFF ] ^   
    311              RT2[ ( Y1 >> 16 ) & 0xFF ] ^   
    312              RT3[ ( Y0 >> 24 ) & 0xFF ];    
    313     }
    314 
    315 
    316 void aes_setkey_enc( aes_context* ctx, const unsigned char* key, int keysize )
    317 {
    318     int i;
    319     unsigned int* RK;
    320 
    321     switch ( keysize )
    322     {
    323         case 128:
    324             ctx->nr = 10;
    325             break;
    326         case 192:
    327             ctx->nr = 12;
    328             break;
    329         case 256:
    330             ctx->nr = 14;
    331             break;
    332         default :
    333             keysize = 128;
    334             ctx->nr = 10;
    335             break;
    336     }
    337 
    338     ctx->rk = RK = ctx->buf;
    339 
    340     memcpy( RK, key, keysize >> 3 );
    341 
    342     switch ( ctx->nr )
    343     {
    344         case 10:
    345             for ( i = 0; i < 10; i++, RK += 4 )
    346             {
    347                 RK[4]  = RK[0] ^ RCON[i] ^
    348                          ( ( unsigned int ) FSb[ ( RK[3] >>  8 ) & 0xFF ]       ) ^
    349                          ( ( unsigned int ) FSb[ ( RK[3] >> 16 ) & 0xFF ] <<  8 ) ^
    350                          ( ( unsigned int ) FSb[ ( RK[3] >> 24 ) & 0xFF ] << 16 ) ^
    351                          ( ( unsigned int ) FSb[ ( RK[3]       ) & 0xFF ] << 24 );
    352 
    353                 RK[5]  = RK[1] ^ RK[4];
    354                 RK[6]  = RK[2] ^ RK[5];
    355                 RK[7]  = RK[3] ^ RK[6];
    356             }
    357             break;
    358         case 12:
    359             for ( i = 0; i < 8; i++, RK += 6 )
    360             {
    361                 RK[6]  = RK[0] ^ RCON[i] ^
    362                          ( ( unsigned int ) FSb[ ( RK[5] >>  8 ) & 0xFF ]       ) ^
    363                          ( ( unsigned int ) FSb[ ( RK[5] >> 16 ) & 0xFF ] <<  8 ) ^
    364                          ( ( unsigned int ) FSb[ ( RK[5] >> 24 ) & 0xFF ] << 16 ) ^
    365                          ( ( unsigned int ) FSb[ ( RK[5]       ) & 0xFF ] << 24 );
    366 
    367                 RK[7]  = RK[1] ^ RK[6];
    368                 RK[8]  = RK[2] ^ RK[7];
    369                 RK[9]  = RK[3] ^ RK[8];
    370                 RK[10] = RK[4] ^ RK[9];
    371                 RK[11] = RK[5] ^ RK[10];
    372             }
    373             break;
    374         case 14:
    375             for ( i = 0; i < 7; i++, RK += 8 )
    376             {
    377                 RK[8]  = RK[0] ^ RCON[i] ^
    378                          ( ( unsigned int ) FSb[ ( RK[7] >>  8 ) & 0xFF ]       ) ^
    379                          ( ( unsigned int ) FSb[ ( RK[7] >> 16 ) & 0xFF ] <<  8 ) ^
    380                          ( ( unsigned int ) FSb[ ( RK[7] >> 24 ) & 0xFF ] << 16 ) ^
    381                          ( ( unsigned int ) FSb[ ( RK[7]       ) & 0xFF ] << 24 );
    382 
    383                 RK[9]  = RK[1] ^ RK[8];
    384                 RK[10] = RK[2] ^ RK[9];
    385                 RK[11] = RK[3] ^ RK[10];
    386 
    387                 RK[12] = RK[4] ^
    388                          ( ( unsigned int ) FSb[ ( RK[11]       ) & 0xFF ]       ) ^
    389                          ( ( unsigned int ) FSb[ ( RK[11] >>  8 ) & 0xFF ] <<  8 ) ^
    390                          ( ( unsigned int ) FSb[ ( RK[11] >> 16 ) & 0xFF ] << 16 ) ^
    391                          ( ( unsigned int ) FSb[ ( RK[11] >> 24 ) & 0xFF ] << 24 );
    392 
    393                 RK[13] = RK[5] ^ RK[12];
    394                 RK[14] = RK[6] ^ RK[13];
    395                 RK[15] = RK[7] ^ RK[14];
    396             }
    397             break;
    398     }
    399 }
    400 
    401 
    402 void aes_setkey_dec( aes_context* ctx, const unsigned char* key, int keysize )
    403 {
    404     int i, j;
    405     aes_context cty;
    406     unsigned int* RK;
    407     unsigned int* SK;
    408 
    409     ctx->rk = RK = ctx->buf;
    410 
    411     aes_setkey_enc( &cty, key, keysize );
    412     ctx->nr = cty.nr;
    413     SK = cty.rk + ( cty.nr << 2 );
    414 
    415     memcpy( RK, SK, sizeof( unsigned int ) << 2 );
    416     RK += 4;
    417     SK -= 4;
    418 
    419     for ( i = ctx->nr - 1; i > 0; i--, SK -= 8 )
    420     {
    421         for ( j = 0; j < 4; j++, SK++ )
    422         {
    423             *RK++ = RT0[ FSb[ ( *SK       ) & 0xFF ] ] ^
    424                     RT1[ FSb[ ( *SK >>  8 ) & 0xFF ] ] ^
    425                     RT2[ FSb[ ( *SK >> 16 ) & 0xFF ] ] ^
    426                     RT3[ FSb[ ( *SK >> 24 ) & 0xFF ] ];
    427         }
    428     }
    429 
    430     memcpy( RK, SK, sizeof( unsigned int ) << 2 );
    431 }
    432 
    433 
    434 void aes_crypt_ecb_update( aes_context* ctx, int mode, const unsigned char input[16], unsigned char output[16] )
    435 {
    436     int i;
    437     unsigned int* RK;
    438     unsigned int X[4], Y[4];
    439 
    440     RK = ctx->rk;
    441 
    442     for ( i = 0; i < 4; i ++ )
    443     {
    444         X[i] = ( *( ( unsigned int* )input + i ) ) ^ ( *RK++ );
    445     }
    446 
    447     if ( mode == AES_DECRYPT )
    448     {
    449         for ( i = ( ctx->nr >> 1 ) - 1; i > 0; i-- )
    450         {
    451             AES_RROUND( Y[0], Y[1], Y[2], Y[3], X[0], X[1], X[2], X[3] );
    452             AES_RROUND( X[0], X[1], X[2], X[3], Y[0], Y[1], Y[2], Y[3] );
    453         }
    454 
    455         AES_RROUND( Y[0], Y[1], Y[2], Y[3], X[0], X[1], X[2], X[3] );
    456 
    457         X[0] = *RK++ ^ 
    458                ( ( unsigned int ) RSb[ ( Y[0]       ) & 0xFF ]       ) ^
    459                ( ( unsigned int ) RSb[ ( Y[3] >>  8 ) & 0xFF ] <<  8 ) ^
    460                ( ( unsigned int ) RSb[ ( Y[2] >> 16 ) & 0xFF ] << 16 ) ^
    461                ( ( unsigned int ) RSb[ ( Y[1] >> 24 ) & 0xFF ] << 24 );
    462 
    463         X[1] = *RK++ ^ 
    464                ( ( unsigned int ) RSb[ ( Y[1]       ) & 0xFF ]       ) ^
    465                ( ( unsigned int ) RSb[ ( Y[0] >>  8 ) & 0xFF ] <<  8 ) ^
    466                ( ( unsigned int ) RSb[ ( Y[3] >> 16 ) & 0xFF ] << 16 ) ^
    467                ( ( unsigned int ) RSb[ ( Y[2] >> 24 ) & 0xFF ] << 24 );
    468 
    469         X[2] = *RK++ ^ 
    470                ( ( unsigned int ) RSb[ ( Y[2]       ) & 0xFF ]       ) ^
    471                ( ( unsigned int ) RSb[ ( Y[1] >>  8 ) & 0xFF ] <<  8 ) ^
    472                ( ( unsigned int ) RSb[ ( Y[0] >> 16 ) & 0xFF ] << 16 ) ^
    473                ( ( unsigned int ) RSb[ ( Y[3] >> 24 ) & 0xFF ] << 24 );
    474 
    475         X[3] = *RK++ ^ 
    476                ( ( unsigned int ) RSb[ ( Y[3]       ) & 0xFF ]       ) ^
    477                ( ( unsigned int ) RSb[ ( Y[2] >>  8 ) & 0xFF ] <<  8 ) ^
    478                ( ( unsigned int ) RSb[ ( Y[1] >> 16 ) & 0xFF ] << 16 ) ^
    479                ( ( unsigned int ) RSb[ ( Y[0] >> 24 ) & 0xFF ] << 24 );
    480     }
    481     else /* AES_ENCRYPT */
    482     {
    483         for ( i = ( ctx->nr >> 1 ) - 1; i > 0; i-- )
    484         {
    485             AES_FROUND( Y[0], Y[1], Y[2], Y[3], X[0], X[1], X[2], X[3] );
    486             AES_FROUND( X[0], X[1], X[2], X[3], Y[0], Y[1], Y[2], Y[3] );
    487         }
    488 
    489         AES_FROUND( Y[0], Y[1], Y[2], Y[3], X[0], X[1], X[2], X[3] );
    490 
    491         X[0] = *RK++ ^ 
    492                ( ( unsigned int ) FSb[ ( Y[0]       ) & 0xFF ]       ) ^
    493                ( ( unsigned int ) FSb[ ( Y[1] >>  8 ) & 0xFF ] <<  8 ) ^
    494                ( ( unsigned int ) FSb[ ( Y[2] >> 16 ) & 0xFF ] << 16 ) ^
    495                ( ( unsigned int ) FSb[ ( Y[3] >> 24 ) & 0xFF ] << 24 );
    496 
    497         X[1] = *RK++ ^ 
    498                ( ( unsigned int ) FSb[ ( Y[1]       ) & 0xFF ]       ) ^
    499                ( ( unsigned int ) FSb[ ( Y[2] >>  8 ) & 0xFF ] <<  8 ) ^
    500                ( ( unsigned int ) FSb[ ( Y[3] >> 16 ) & 0xFF ] << 16 ) ^
    501                ( ( unsigned int ) FSb[ ( Y[0] >> 24 ) & 0xFF ] << 24 );
    502 
    503         X[2] = *RK++ ^ 
    504                ( ( unsigned int ) FSb[ ( Y[2]       ) & 0xFF ]       ) ^
    505                ( ( unsigned int ) FSb[ ( Y[3] >>  8 ) & 0xFF ] <<  8 ) ^
    506                ( ( unsigned int ) FSb[ ( Y[0] >> 16 ) & 0xFF ] << 16 ) ^
    507                ( ( unsigned int ) FSb[ ( Y[1] >> 24 ) & 0xFF ] << 24 );
    508 
    509         X[3] = *RK++ ^ 
    510                ( ( unsigned int ) FSb[ ( Y[3]       ) & 0xFF ]       ) ^
    511                ( ( unsigned int ) FSb[ ( Y[0] >>  8 ) & 0xFF ] <<  8 ) ^
    512                ( ( unsigned int ) FSb[ ( Y[1] >> 16 ) & 0xFF ] << 16 ) ^
    513                ( ( unsigned int ) FSb[ ( Y[2] >> 24 ) & 0xFF ] << 24 );
    514     }
    515 
    516     memcpy( output, X, 16 );
    517 }
    518 
    519 // free later
    520 unsigned char* aes_crypt_ecb( aes_context* ctx, int mode, const unsigned char* input, int slen, int* dlen )
    521 {
    522     register int i;
    523     register int n;
    524     unsigned char* output;
    525     unsigned char buff[16];
    526 
    527     if ( mode == AES_ENCRYPT )
    528     {
    529         n = 16 - ( slen & 15 );
    530         *dlen = slen + n;
    531 
    532         output = ( unsigned char* )malloc( *dlen );
    533         if ( !output )
    534         {
    535             return NULL;
    536         }
    537 
    538         memset( buff, n, sizeof( buff ) );
    539         if ( slen & 15 )
    540         {
    541             memcpy( buff, input + ( slen & ~15 ), slen & 15 );
    542         }
    543 
    544         n = ( slen >> 4 );
    545         for ( i = 0; i < n; i ++ )
    546         {
    547             aes_crypt_ecb_update( ctx, AES_ENCRYPT, 
    548                                   input + ( i << 4 ), output + ( i << 4 ) );
    549         }
    550         aes_crypt_ecb_update( ctx, AES_ENCRYPT, buff, output + ( i << 4 ) );
    551     }
    552     else
    553     {
    554         output = ( unsigned char* )malloc( slen );
    555         if ( !output )
    556         {
    557             return NULL;
    558         }
    559 
    560         n = ( slen >> 4 );
    561         for ( i = 0; i < n; i ++ )
    562         {
    563             aes_crypt_ecb_update( ctx, AES_DECRYPT, 
    564                                   input + ( i << 4 ), output + ( i << 4 ) );
    565         }
    566 
    567         *dlen = slen - ( int )output[slen - 1];
    568     }
    569 
    570     return output;
    571 }

    与BASE64经常一起用

      1 #include "base64.h"
      2 
      3 static const unsigned char base64_enc_map[64] =
      4 {
      5     'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
      6     'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T',
      7     'U', 'V', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd',
      8     'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
      9     'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x',
     10     'y', 'z', '0', '1', '2', '3', '4', '5', '6', '7',
     11     '8', '9', '+', '/'
     12 };
     13 
     14 static const unsigned char base64_dec_map[128] =
     15 {
     16     127, 127, 127, 127, 127, 127, 127, 127, 127, 127,
     17     127, 127, 127, 127, 127, 127, 127, 127, 127, 127,
     18     127, 127, 127, 127, 127, 127, 127, 127, 127, 127,
     19     127, 127, 127, 127, 127, 127, 127, 127, 127, 127,
     20     127, 127, 127,  62, 127, 127, 127,  63,  52,  53,
     21     54,  55,  56,  57,  58,  59,  60,  61, 127, 127,
     22     127,  64, 127, 127, 127,   0,   1,   2,   3,   4,
     23     5,   6,   7,   8,   9,  10,  11,  12,  13,  14,
     24     15,  16,  17,  18,  19,  20,  21,  22,  23,  24,
     25     25, 127, 127, 127, 127, 127, 127,  26,  27,  28,
     26     29,  30,  31,  32,  33,  34,  35,  36,  37,  38,
     27     39,  40,  41,  42,  43,  44,  45,  46,  47,  48,
     28     49,  50,  51, 127, 127, 127, 127, 127
     29 };
     30 
     31 
     32 int base64_encode( char* dst, int* dlen, const unsigned char* src, int slen )
     33 {
     34     int i, n;
     35     int C1, C2, C3;
     36     char* p;
     37 
     38     if ( slen == 0 )
     39     {
     40         return 0;
     41     }
     42 
     43     n = ( slen << 3 ) / 6;
     44 
     45     switch ( ( slen << 3 ) - ( n * 6 ) )
     46     {
     47         case  2:
     48             n += 3;
     49             break;
     50         case  4:
     51             n += 2;
     52             break;
     53         default:
     54             break;
     55     }
     56 
     57     if ( *dlen < n + 1 )
     58     {
     59         *dlen = n + 1;
     60         return -1;
     61     }
     62 
     63     n = ( slen / 3 ) * 3;
     64 
     65     for ( i = 0, p = dst; i < n; i += 3 )
     66     {
     67         C1 = *src++;
     68         C2 = *src++;
     69         C3 = *src++;
     70 
     71         *p++ = base64_enc_map[( C1 >> 2 ) & 0x3F];
     72         *p++ = base64_enc_map[( ( ( C1 &  3 ) << 4 ) + ( C2 >> 4 ) ) & 0x3F];
     73         *p++ = base64_enc_map[( ( ( C2 & 15 ) << 2 ) + ( C3 >> 6 ) ) & 0x3F];
     74         *p++ = base64_enc_map[C3 & 0x3F];
     75     }
     76 
     77     if ( i < slen )
     78     {
     79         C1 = *src++;
     80         C2 = ( ( i + 1 ) < slen ) ? *src++ : 0;
     81 
     82         *p++ = base64_enc_map[( C1 >> 2 ) & 0x3F];
     83         *p++ = base64_enc_map[( ( ( C1 & 3 ) << 4 ) + ( C2 >> 4 ) ) & 0x3F];
     84 
     85         if ( ( i + 1 ) < slen )
     86         {
     87             *p++ = base64_enc_map[( ( C2 & 15 ) << 2 ) & 0x3F];
     88         }
     89         else
     90         {
     91             *p++ = '=';
     92         }
     93 
     94         *p++ = '=';
     95     }
     96 
     97     *dlen = p - dst;
     98     *p = 0;
     99 
    100     return 0;
    101 }
    102 
    103 
    104 int base64_decode( unsigned char* dst, int* dlen, const char* src, int slen )
    105 {
    106     int i, j, n;
    107     unsigned int x;
    108     unsigned char* p;
    109 
    110     if ( slen == 0 )
    111     {
    112         return 0;
    113     }
    114 
    115     for ( i = j = n = 0; i < slen; i++ )
    116     {
    117         if ( ( slen - i ) >= 2 &&
    118                 src[i] == '
    ' && src[i + 1] == '
    ' )
    119         {
    120             continue;
    121         }
    122 
    123         if ( src[i] == '
    ' )
    124         {
    125             continue;
    126         }
    127 
    128         if ( src[i] == '=' && ++j > 2 )
    129         {
    130             return -1;
    131         }
    132 
    133         if ( src[i] < 0 || base64_dec_map[( int )src[i]] == 127 )
    134         {
    135             return -1;
    136         }
    137 
    138         if ( base64_dec_map[( int )src[i]] < 64 && j != 0 )
    139         {
    140             return -1;
    141         }
    142 
    143         n++;
    144     }
    145 
    146     if ( n == 0 )
    147     {
    148         return 0;
    149     }
    150 
    151     n = ( ( n * 6 ) + 7 ) >> 3;
    152 
    153     if ( *dlen < n )
    154     {
    155         *dlen = n;
    156         return -1;
    157     }
    158 
    159     for ( j = 3, n = x = 0, p = dst; i > 0; i--, src++ )
    160     {
    161         if ( *src == '
    ' || *src == '
    ' )
    162         {
    163             continue;
    164         }
    165 
    166         j -= ( base64_dec_map[( int ) * src] == 64 );
    167         x  = ( x << 6 ) | ( base64_dec_map[( int ) * src] & 0x3F );
    168 
    169         if ( ++ n == 4 )
    170         {
    171             n = 0;
    172 
    173             if ( j > 0 ) *p++ = ( unsigned char )( x >> 16 );
    174 
    175             if ( j > 1 ) *p++ = ( unsigned char )( x >>  8 );
    176 
    177             if ( j > 2 ) *p++ = ( unsigned char )( x     );
    178         }
    179     }
    180 
    181     *dlen = p - dst;
    182 
    183     return 0;
    184 }
  • 相关阅读:
    二维数组的最大联通子数组
    四则运算网页终结版
    Python+Selenium进阶版(四)-封装一个自己的类-浏览器引擎类
    Python+Selenium进阶版(三)- 二次封装Selenium中几个方法
    Python+Selenium进阶版(二)- Python中类/函数/模块的简单介绍
    Python+Selenium进阶版 (一)- Python IDE工具-PyCharm的安装和使用
    Python+Selenium学习-Xpat增强梳理版
    Python+Selenium练习(三十一)- 截图并保存
    Python+Selenium练习(三十)- 获取页面元素的href属性
    Python+Selenium练习(二十九)- 获取当前页面全部图片信息
  • 原文地址:https://www.cnblogs.com/javado/p/4506822.html
Copyright © 2011-2022 走看看