📄 des.c
字号:
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 + -