⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 des.c

📁 经典的加密程序
💻 C
📖 第 1 页 / 共 2 页
字号:
            X = ((X <<  2) | (X >> 26)) & 0x0FFFFFFF;            Y = ((Y <<  2) | (Y >> 26)) & 0x0FFFFFFF;        }        *SK++ =   ((X <<  4) & 0x24000000) | ((X << 28) & 0x10000000)                | ((X << 14) & 0x08000000) | ((X << 18) & 0x02080000)                | ((X <<  6) & 0x01000000) | ((X <<  9) & 0x00200000)                | ((X >>  1) & 0x00100000) | ((X << 10) & 0x00040000)                | ((X <<  2) & 0x00020000) | ((X >> 10) & 0x00010000)                | ((Y >> 13) & 0x00002000) | ((Y >>  4) & 0x00001000)                | ((Y <<  6) & 0x00000800) | ((Y >>  1) & 0x00000400)                | ((Y >> 14) & 0x00000200) | ((Y      ) & 0x00000100)                | ((Y >>  5) & 0x00000020) | ((Y >> 10) & 0x00000010)                | ((Y >>  3) & 0x00000008) | ((Y >> 18) & 0x00000004)                | ((Y >> 26) & 0x00000002) | ((Y >> 24) & 0x00000001);        *SK++ =   ((X << 15) & 0x20000000) | ((X << 17) & 0x10000000)                | ((X << 10) & 0x08000000) | ((X << 22) & 0x04000000)                | ((X >>  2) & 0x02000000) | ((X <<  1) & 0x01000000)                | ((X << 16) & 0x00200000) | ((X << 11) & 0x00100000)                | ((X <<  3) & 0x00080000) | ((X >>  6) & 0x00040000)                | ((X << 15) & 0x00020000) | ((X >>  4) & 0x00010000)                | ((Y >>  2) & 0x00002000) | ((Y <<  8) & 0x00001000)                | ((Y >> 14) & 0x00000808) | ((Y >>  9) & 0x00000400)                | ((Y      ) & 0x00000200) | ((Y <<  7) & 0x00000100)                | ((Y >>  7) & 0x00000020) | ((Y >>  3) & 0x00000011)                | ((Y <<  2) & 0x00000004) | ((Y >> 21) & 0x00000002);    }    return( 0 );}int des_set_key( des_context *ctx, uint8 key[8] ){    int i;    /* setup encryption subkeys */    des_main_ks( ctx->esk, key );    /* setup decryption subkeys */    for( i = 0; i < 32; i += 2 )    {        ctx->dsk[i    ] = ctx->esk[30 - i];        ctx->dsk[i + 1] = ctx->esk[31 - i];    }    return( 0 );}/* DES 64-bit block encryption/decryption */void des_crypt( uint32 SK[32], uint8 input[8], uint8 output[8] ){    uint32 X, Y, T;    GET_UINT32( X, input, 0 );    GET_UINT32( Y, input, 4 );    DES_IP( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_FP( Y, X );    PUT_UINT32( Y, output, 0 );    PUT_UINT32( X, output, 4 );}void des_encrypt( des_context *ctx, uint8 input[8], uint8 output[8] ){    des_crypt( ctx->esk, input, output );}void des_decrypt( des_context *ctx, uint8 input[8], uint8 output[8] ){    des_crypt( ctx->dsk, input, output );}/* Triple-DES key schedule */int des3_set_2keys( des3_context *ctx, uint8 key1[8], uint8 key2[8] ){    int i;    des_main_ks( ctx->esk     , key1 );    des_main_ks( ctx->dsk + 32, key2 );    for( i = 0; i < 32; i += 2 )    {        ctx->dsk[i     ] = ctx->esk[30 - i];        ctx->dsk[i +  1] = ctx->esk[31 - i];        ctx->esk[i + 32] = ctx->dsk[62 - i];        ctx->esk[i + 33] = ctx->dsk[63 - i];        ctx->esk[i + 64] = ctx->esk[     i];        ctx->esk[i + 65] = ctx->esk[ 1 + i];        ctx->dsk[i + 64] = ctx->dsk[     i];        ctx->dsk[i + 65] = ctx->dsk[ 1 + i];    }    return( 0 );}int des3_set_3keys( des3_context *ctx, uint8 key1[8], uint8 key2[8],                                       uint8 key3[8] ){    int i;    des_main_ks( ctx->esk     , key1 );    des_main_ks( ctx->dsk + 32, key2 );    des_main_ks( ctx->esk + 64, key3 );    for( i = 0; i < 32; i += 2 )    {        ctx->dsk[i     ] = ctx->esk[94 - i];        ctx->dsk[i +  1] = ctx->esk[95 - i];        ctx->esk[i + 32] = ctx->dsk[62 - i];        ctx->esk[i + 33] = ctx->dsk[63 - i];        ctx->dsk[i + 64] = ctx->esk[30 - i];        ctx->dsk[i + 65] = ctx->esk[31 - i];    }    return( 0 );}/* Triple-DES 64-bit block encryption/decryption */void des3_crypt( uint32 SK[96], uint8 input[8], uint8 output[8] ){    uint32 X, Y, T;    GET_UINT32( X, input, 0 );    GET_UINT32( Y, input, 4 );    DES_IP( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( X, Y );  DES_ROUND( Y, X );    DES_ROUND( X, Y );  DES_ROUND( Y, X );    DES_ROUND( X, Y );  DES_ROUND( Y, X );    DES_ROUND( X, Y );  DES_ROUND( Y, X );    DES_ROUND( X, Y );  DES_ROUND( Y, X );    DES_ROUND( X, Y );  DES_ROUND( Y, X );    DES_ROUND( X, Y );  DES_ROUND( Y, X );    DES_ROUND( X, Y );  DES_ROUND( Y, X );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_ROUND( Y, X );  DES_ROUND( X, Y );    DES_FP( Y, X );    PUT_UINT32( Y, output, 0 );    PUT_UINT32( X, output, 4 );}void des3_encrypt( des3_context *ctx, uint8 input[8], uint8 output[8] ){    des3_crypt( ctx->esk, input, output );}void des3_decrypt( des3_context *ctx, uint8 input[8], uint8 output[8] ){    des3_crypt( ctx->dsk, input, output );}//#ifdef TEST#include <string.h>#include <stdio.h>/* * Triple-DES Monte Carlo Test: ECB mode * source: NIST - tripledes-vectors.zip */static unsigned char DES3_keys[3][8] ={    { 0x01, 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF },    { 0x23, 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF, 0x01 },    { 0x45, 0x67, 0x89, 0xAB, 0xCD, 0xEF, 0x01, 0x23 }};static unsigned char DES3_init[8] ={    0x4E, 0x6F, 0x77, 0x20, 0x69, 0x73, 0x20, 0x74};static unsigned char DES3_enc_test[3][8] ={    { 0x6A, 0x2A, 0x19, 0xF4, 0x1E, 0xCA, 0x85, 0x4B },    { 0x03, 0xE6, 0x9F, 0x5B, 0xFA, 0x58, 0xEB, 0x42 },    { 0xDD, 0x17, 0xE8, 0xB8, 0xB4, 0x37, 0xD2, 0x32 }};    static unsigned char DES3_dec_test[3][8] ={    { 0xCD, 0xD6, 0x4F, 0x2F, 0x94, 0x27, 0xC1, 0x5D },    { 0x69, 0x96, 0xC8, 0xFA, 0x47, 0xA2, 0xAB, 0xEB },    { 0x83, 0x25, 0x39, 0x76, 0x44, 0x09, 0x1A, 0x0A }};int main( void ){    int m, n, i;    des_context ctx;    des3_context ctx3;    unsigned char buf[8];    for( m = 0; m < 2; m++ )    {        printf( "\n Triple-DES Monte Carlo Test (ECB mode) - " );        if( m == 0 ) printf( "encryption\n\n" );        if( m == 1 ) printf( "decryption\n\n" );        for( n = 0; n < 3; n++ )        {            printf( " Test %d, key size = %3d bits: ",                    n + 1, 64 + n * 64 );            fflush( stdout );            memcpy( buf, DES3_init, 8 );            switch( n )            {                case 0:                    des_set_key( &ctx, DES3_keys[0] );                    break;                case 1:                    des3_set_2keys( &ctx3, DES3_keys[0],                                           DES3_keys[1] );                    break;                case 2:                    des3_set_3keys( &ctx3, DES3_keys[0],                                           DES3_keys[1],                                           DES3_keys[2] );                    break;            }            for( i = 0; i < 10000; i++ )            {                if( n == 0 )                {                    if( m == 0 ) des_encrypt( &ctx, buf, buf );                    if( m == 1 ) des_decrypt( &ctx, buf, buf );                }                else                {                    if( m == 0 ) des3_encrypt( &ctx3, buf, buf );                    if( m == 1 ) des3_decrypt( &ctx3, buf, buf );                }            }            if( ( m == 0 && memcmp( buf, DES3_enc_test[n], 8 ) ) ||                ( m == 1 && memcmp( buf, DES3_dec_test[n], 8 ) ) )            {                printf( "failed!\n" );                return( 1 );            }            printf( "passed.\n" );        }    }    printf( "\n" );    return( 0 );}//#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -