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

📄 des.cpp

📁 单钥密码算法 AES DES IDEA LZW RC5
💻 CPP
📖 第 1 页 / 共 2 页
字号:
#include "stdafx.h"

#include "stdio.h"
#define EN0   0      /* MODE == encrypt */
#define DE1   1      /* MODE == decrypt */

typedef struct {
		unsigned   long  ek[32];   // encrypt key
		unsigned   long  dk[32];   //
} des_ctx;

extern void deskey ( unsigned char *, short );
/*                    hexkey[8]        MODE
 * Sets the internal key register according to the hexadecimal 
 * Key contained in the 8 bytes of hexkey , according to the DES,
 * for encryption or decryption according to MODE. 
 */

extern void usekey ( unsigned long * );
/*                cookedkey[32]  
 * Loads the internal key register with the data in cookedkey.
 */

extern void cpkey ( unsigned long * );
/*                cookedkey[32]  
 * Copies the contents of the internal key register into the storage
 * located at &cookedkey[0].
 */

extern void des ( unsigned char *, unsigned char * );
/*           from[8]      to[8]     
 * Encrypts/Decrypts (according to the key currently loaded in the
 * internal key register) one block of eight bytes at address 'form'
 * into the block at address 'to'. They can be the same.
 * Not use in this file
 */

static void scrunch(unsigned char *, unsigned long * );
static void unscrun(unsigned long *, unsigned char * );
static void desfunc(unsigned long *, unsigned long * );
static void cookey(unsigned long *);

static unsigned long KnL[32] = { 0L };  //密钥使用时的存储空间
static unsigned long KnR[32] = { 0L };
static unsigned long Kn3[32] = { 0L };
static unsigned char Df_Key[24] = {
		0x01,0x23,0x45,0x67,0x89,0xab,0xcd,0xef,
		0xfe,0xdc,0xba,0x98,0x76,0x54,0x32,0x10,
		0x89,0xab,0xcd,0xef,0x01,0x23,0x45,0x67 };

static unsigned short bytebit[8] = {
		0200,0100,040,020,010,04,02,01 }; //和位与&操作相结合  提取byte中bit

static unsigned long bigbyte[24] = {    
		0x800000L,0x400000L,0x200000L,0x100000L,
		0x80000L,0x40000L,0x20000L,0x10000L,
		0x8000L,0x4000L,0x2000L,0x1000L,
		0x800L,0x400L,0x200L,0x100L,
		0x80L,0x40L,0x20L,0x10L,
		0x8L,0x4L,0x2L,0x1L  }; 
		//bigbyte[24]和位或 | 操作相结合,设置Long中的byte值

/* Use the key schedule specified in the Standard (ANSI X3.92-1981).*/
//pc1 pc2从0开始计数
 static unsigned char pc1[56] = {
		56, 48, 40, 32, 24, 16,  8,  0, 57, 49, 41, 33, 25, 17,
		 9,  1, 58, 50, 42, 34, 26, 18, 10,  2, 59, 51, 43, 35,
		62, 54, 46, 38, 30, 22, 14,  6, 61, 53, 45, 37, 29, 21,
		13,  5, 60, 52, 44, 36, 28, 20, 12,  4, 27, 19, 11,  3  };

static unsigned char totrot[16] = {
	1, 2, 4, 6, 8, 10, 12, 14, 15, 17, 19, 21, 23, 25, 27, 28 };
//每轮子密钥移动的位数(从原始密钥计起)

static unsigned char pc2[48] = {
		13, 16, 10, 23,  0,  4,     2, 27, 14,  5, 20,  9,
		22, 18, 11,  3, 25,  7,    15,  6, 26, 19, 12,  1,
		40, 51, 30, 36, 46, 54,    29, 39, 50, 44, 32, 47,
		43, 48, 38, 55, 33, 52,    45, 41, 49, 35, 28, 31  };
/*
void deskey(key, edf)   Thanks to James Gillogly & Phil Karn! 
unsigned char * key;  */
/*  use pc1, pc2. P16,11  
 *  data: long kn[32] -> cookey 
 */
void deskey(unsigned char * key,short edf)  /* Thanks to James Gillogly & Phil Karn! */ 
{
	register int i, j, l, m, n;
	unsigned char pclm[56], pcr[56];//pclm 原始密钥经压缩的结果  pcr 每轮子密钥
	unsigned long kn[32];//

	for ( j = 0; j <56; j++ ) {
		l = pc1[j];    //l 原密码中bit序号
		m = l & 07;   //m=l%8  m表示char内选择位
		pclm[j] = ( key[l >> 3] & bytebit[m]) ? 1 : 0; 
		//(key+l/8) 访问粒度 char  bytebit   & 位提取		
	}
	for ( i = 0; i <16; i++ ) {  //i 表示轮数 kn[m]kn[n]表一轮的subkey
		if( edf == DE1 ) m = (15 - i) << 1 ;//加密密钥与解密密钥仅顺序不同
		else m = i << 1;
		n = m + 1;
		kn[m] = kn[n] = 0L;
		for( j = 0; j < 28; j++ ) {
			l = j + totrot[i];   //移动位置
			if( l < 28 ) pcr[j] = pclm[l];
			else pcr[j] = pclm[ l - 28];
		}
		for( j = 28; j < 56; j++ ) {
			l = j + totrot[i];
			if( l < 56 ) pcr[j] = pclm[l];
			else pcr[j] = pclm[ l - 28];
		}
		for( j = 0; j < 24; j++ ) {
			l = j + totrot[i];
			if( pcr[pc2[j]] ) kn[m] |= bigbyte[j]; //设置long中的byte
			if( pcr[pc2[j+24]] ) kn[n] |= bigbyte[j];
		}
	cookey(kn);
	return;
	}
}

/*static void cookey(rawl)
register unsigned long *rawl;*/
/* get long raw1[32] from deskey(), and to usekey();
 */
static void cookey(register unsigned long *raw1)
{
	register unsigned long *cook, *raw0;
	unsigned long dough[32];
	register int i;

	cook = dough;
	for ( i = 0; i < 16; i++, raw1++ ) {
		raw0 = raw1++;
		*cook  = ( *raw0 & 0x00fc0000L ) << 6;
		*cook |= ( *raw0 & 0x00000fc0L ) <<10;
		*cook |= ( *raw1 & 0x00fc0000L ) >>10;
		*cook++   |= ( *raw1 & 0x00000fc0L ) >> 6;
        *cook  = ( *raw0 & 0x0003f000L ) <<12;
		*cook |= ( *raw0 & 0x0000003fL ) <<16;
		*cook |= ( *raw1 & 0x0003f000L ) >> 4;
		*cook++   |= ( *raw1 & 0x0000003fL ) ;
	}	
	usekey(dough);
	return;
}

/*void cpkey(into)
register unsigned long *into;*/
/* 
 * copy  KnL[32] to destiny
 */
extern void cpkey(register unsigned long *into)
{
	register unsigned long *from, *endp;

	from = KnL, endp = &KnL[32];
	while ( from < endp ) *into++ = *from++;
	return;
}

/*void usekey(from)
register unsigned long *from;*/
/* 
 * copy long[32]  to KnL[32]
 */
extern void usekey(register unsigned long *from)
{
	register unsigned long *to, *endp;

	to   = KnL, endp = &KnL[32];
	while ( to < endp )  *to++ = *from++;
	return;
}

/*void des(inblock, outblock)
unsigned char *inblock, *outblock;*/
void des(unsigned char *inblock, unsigned char *outblock)
{
	unsigned long work[2];

	scrunch(inblock, work);
	desfunc(work, KnL);
	unscrun(work, outblock);
	return;
}

/*static void scrunch(outof, into)
register unsigned char * outof;
register unsigned long * into;
将明文压缩为long[2]
*/
static void scrunch(register unsigned char * outof, register unsigned long * into)
{
	*into  = (*outof++ & 0xffL) <<24;
	*into |= (*outof++ & 0xffL) <<16;
	*into |= (*outof++ & 0xffL) << 8;
	*into++ |= (*outof++ & 0xffL) ;
	*into  = (*outof++ & 0xffL) <<24;
	*into |= (*outof++ & 0xffL) <<16;
	*into |= (*outof++ & 0xffL) << 8;
	*into |= (*outof   & 0xffL)   ;
	return;
}

/*static void unscrun(outof, into)
register unsigned long * outof;
register unsigned char * into;
还原为字符
*/
static void unscrun(register unsigned long * outof, register unsigned char * into)
{
	*into++  = (*outof >>24) & 0xffL ;
	*into++  = (*outof >>16) & 0xffL ;
	*into++  = (*outof >> 8) & 0xffL ;
	*into++  =  *outof++ & 0xffL;
	*into++  = (*outof >>24) & 0xffL ;
	*into++  = (*outof >>16) & 0xffL ;
	*into++  = (*outof >> 8) & 0xffL ;
	*into    =  *outof   & 0xffL   ;
	return;
}
	
static unsigned long sp1[64] = {
	0x01010400L,  0x00000000L,  0x00010000L,  0x01010404L,
	0x01010004L,  0x00010404L,  0x00000004L,  0x00010000L,
	0x00000400L,  0x01010400L,  0x01010404L,  0x00000400L,
	0x01000404L,  0x01010004L,  0x01000000L,  0x00000004L,

	0x00000404L,  0x01000400L,  0x01000400L,  0x00010400L,
	0x00010400L,  0x01010000L,  0x01010000L,  0x01000404L,
	0x00010004L,  0x01000004L,  0x01000004L,  0x00010004L,
	0x00000000L,  0x00000404L,  0x00010404L,  0x01000000L,

	0x00010000L,  0x01010404L,  0x00000004L,  0x01010000L,
	0x01010400L,  0x01000000L,  0x01000000L,  0x00000400L,
	0x01010004L,  0x00010000L,  0x00010400L,  0x01000004L,
	0x00000400L,  0x00000004L,  0x01000404L,  0x00010404L,

	0x01010404L,  0x00010004L,  0x01010000L,  0x01000404L,
	0x01000004L,  0x00000404L,  0x00010404L,  0x01010400L,
	0x00000404L,  0x01000400L,  0x01000400L,  0x00000000L,
	0x00010004L,  0x00010400L,  0x00000000L,  0x01010004L  };

static unsigned long sp2[64] = {
	0x80108020L,  0x80008000L,  0x00008000L,  0x00108020L,
	0x00100000L,  0x00000020L,  0x80100020L,  0x80008020L,
	0x80000020L,  0x80108020L,  0x80108000L,  0x80000000L,
	0x80008000L,  0x00100000L,  0x00000020L,  0x80100020L,

	0x00108000L,  0x00100020L,  0x80008020L,  0x00000000L,
	0x80000000L,  0x00008000L,  0x00108020L,  0x80100000L,
	0x00100020L,  0x80000020L,  0x00000000L,  0x00108000L,
	0x00008020L,  0x80108000L,  0x80100000L,  0x00008020L,

	0x00000000L,  0x00108020L,  0x80100020L,  0x00100000L,
	0x80008020L,  0x80100000L,  0x80108000L,  0x00008000L,
	0x80100000L,  0x80008000L,  0x00000020L,  0x80108020L,
	0x00108020L,  0x00000020L,  0x00008000L,  0x80000000L,

	0x00008020L,  0x80108000L,  0x00100000L,  0x80000020L,
	0x00100020L,  0x80008020L,  0x80000020L,  0x00100020L,
	0x00108000L,  0x00000000L,  0x80008000L,  0x00008020L,
	0x80000000L,  0x80100020L,  0x80108020L,  0x00108000L  };


static unsigned long sp3[64] = {
	0x00000208L,  0x08020200L,  0x00000000L,  0x08020008L,
	0x08000200L,  0x00000000L,  0x00020208L,  0x08000200L,
	0x00020008L,  0x08000008L,  0x08000008L,  0x00020000L,
	0x08020208L,  0x00020008L,  0x08020000L,  0x00000208L,

	0x08000000L,  0x00000008L,  0x08020200L,  0x00000200L,
	0x00020200L,  0x08020000L,  0x08020008L,  0x00020208L,
	0x08000208L,  0x00020200L,  0x00020000L,  0x08000208L,
	0x00000008L,  0x08020208L,  0x00000200L,  0x08000000L,

	0x08020200L,  0x08000000L,  0x00020008L,  0x00000208L,
	0x00020000L,  0x08020200L,  0x08000200L,  0x00000000L,
	0x00000200L,  0x00020008L,  0x08020208L,  0x08000200L,
	0x08000008L,  0x00000200L,  0x00000000L,  0x08020008L,

	0x08000208L,  0x00020000L,  0x08000000L,  0x08020208L,
	0x00000008L,  0x00020208L,  0x00020200L,  0x08000008L,
	0x08020000L,  0x08000208L,  0x00000208L,  0x08020000L,
	0x00020208L,  0x00000008L,  0x08020008L,  0x00020200L  };
	

static unsigned long sp4[64] = {
	0x00802001L,  0x00002081L,  0x00002081L,  0x00000080L,
	0x00802080L,  0x00800081L,  0x00800001L,  0x00002001L,
	0x00000000L,  0x00802000L,  0x00802000L,  0x00802081L,
	0x00000081L,  0x00000000L,  0x00800080L,  0x00800001L,

	0x00000001L,  0x00002000L,  0x00800000L,  0x00802001L,
	0x00000080L,  0x00800000L,  0x00002001L,  0x00002080L,
	0x00800081L,  0x00000001L,  0x00002080L,  0x00800080L,
	0x00002000L,  0x00802080L,  0x00802081L,  0x00000081L,

	0x00800080L,  0x00800001L,  0x00802000L,  0x00802081L,
	0x00000081L,  0x00000000L,  0x00000000L,  0x00802000L,

⌨️ 快捷键说明

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