亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? d3des.c

?? des加解密實現(xiàn)
?? C
?? 第 1 頁 / 共 2 頁
字號:

#include "d3des.h"

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 };

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	};

/* Use the key schedule specified in the Standard (ANSI X3.92-1981). */

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)	
unsigned char *key;
short edf;
{
	register int i, j, l, m, n;
	unsigned char pc1m[56], pcr[56];
	unsigned long kn[32];
              /*******************************************************************/
              //key為八位的 數(shù)組,如key[8]="abcedfgh",8等于2的3次冪,而每一個字節(jié)也是八位,同樣8等于2的3次冪
              //所以所有64位只需6位下標(biāo)就可以全部標(biāo)識。
              //高三位下標(biāo)確定是key中的哪一個字符,低三位確定是字符中的哪一位。
              /**********************************************************************************/
	for ( j = 0; j < 56; j++ ) {
		l = pc1[j];//for example l=56 when j=0;
		m = l & 07;  //m為低三位
		pc1m[j] = (key[l >> 3] & bytebit[m]) ? 1 : 0;
		//l>>3確定高三位,bytebit[m]確定要置換的哪一位,兩數(shù)"與"即為置換。
		}               
	for( i = 0; i < 16; i++ ) {
		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++ ) { 
		    //實現(xiàn)循環(huán)右移對應(yīng)位數(shù)的操作,前28位作為一個集合。
		    //totrot[i]決定循環(huán)右移的位數(shù)
			l = j + totrot[i];//if j=0 then l= 0+1 =1 
			                  //if j=27, then l=27+1=28			                   
			if( l < 28 ) pcr[j] = pc1m[l];
			else pcr[j] = pc1m[l - 28];
			}
		for( j = 28; j < 56; j++ ) {
		//實現(xiàn)循環(huán)右移對應(yīng)位數(shù)的操作,后28位作為一個集合。
		    l = j + totrot[i];
		    if( l < 56 ) pcr[j] = pc1m[l];
		    else pcr[j] = pc1m[l - 28];
		    }
		for( j = 0; j < 24; j++ ) {
		    //此為一個置換,最終是把56位置換成48位;如果置換后的那一位為1,則密鑰中相應(yīng)的位置1,共形成兩個24位的密鑰
			if( pcr[pc2[j]] ) kn[m] |= bigbyte[j];
			if( pcr[pc2[j+24]] ) kn[n] |= bigbyte[j];
			}
		}
		//到目前為止形成了32個單元的數(shù)組,每個單元如:0X00FFFFFF的形式(此值代表32的long型中只有后24位存放有效數(shù)字)
	
	//cookey的最終目的是把兩個0x00ffffff形式的long型值變成兩個0x3f3f3f3f形式的long型值,即把集中存放的key值分散開來放。
	cookey(kn);
	return;
	}

static void cookey(raw1)
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為前24位,raw1為后24位
		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);
		}
		
		//前24位,每六位一組,每組一個標(biāo)號
		111111(1),111111(5),111111(2),111111(6)
		//后24位,每六位一組,每組一個標(biāo)號
		111111(3),111111(7),111111(4),111111(8)
		拼成兩個32位的串:
		0x3f3f3f3f(組號為1234)
		0x3f3f3f3f(組號為5678)
		
		
		
		
		
	//最終把形成的密鑰存放在全局變量KnL中	
	usekey(dough);
	return;
	}

void cpkey(into)
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;
{       
        //最終把形成的密鑰存放在全局變量KnL中
	register unsigned long *to, *endp;

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

void des(inblock, outblock)
unsigned char *inblock, *outblock;
{
	unsigned long work[2];
         
	scrunch(inblock, work);//該函數(shù)的作用是把一個8位字符串4個為一組放到兩個long型單元中,long型單元就是數(shù)組work
	desfunc(work, KnL);   //實質(zhì)性的加解密操作,把解密后的信息放回work所指向的空間中。
	unscrun(work, outblock);//把兩個long型單元拼成一個八位的字符串
	return;
	}

static void scrunch(outof, into)
register unsigned char *outof;
register unsigned long *into;
{         //outof="abcdefgh"
         //該函數(shù)的作用是把一個8位字符串4個為一組放到兩個long型單元中
	*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;
{
	*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,

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀99久久精品久久久久久软件 | 紧缚捆绑精品一区二区| 欧美日韩国产成人在线免费| 亚洲福利视频一区| 欧美日韩成人一区| 免费欧美日韩国产三级电影| 精品国精品国产尤物美女| 国产一区二区主播在线| 亚洲国产精品成人综合| 日本韩国欧美一区| 日本午夜一本久久久综合| 26uuu色噜噜精品一区| 成人精品电影在线观看| 一区免费观看视频| 555www色欧美视频| 国产成人精品一区二区三区网站观看| 国产精品久久久久婷婷| 欧美三级电影一区| 国内精品免费**视频| 日韩美女视频一区| 7777精品伊人久久久大香线蕉| 韩国av一区二区| 亚洲免费观看在线视频| 91精品国产综合久久精品| 国产精品综合二区| 亚洲黄色尤物视频| 欧美精品一区二区蜜臀亚洲| 99久久精品免费| 日韩 欧美一区二区三区| 日本不卡视频一二三区| 国产日韩精品一区二区三区 | 亚洲欧洲日产国码二区| 精品视频色一区| 国产激情视频一区二区三区欧美| 亚洲欧美一区二区三区极速播放| 日韩免费看的电影| 色狠狠色噜噜噜综合网| 狠狠色丁香久久婷婷综合丁香| 成人欧美一区二区三区白人| 在线播放国产精品二区一二区四区| 国产精品一区免费在线观看| 亚洲妇熟xx妇色黄| 亚洲人精品一区| 2021久久国产精品不只是精品| 欧美少妇xxx| 国产不卡在线播放| 一区二区三区国产| 国产精品色在线观看| 欧美一区二区三区在| 色94色欧美sute亚洲线路二 | www.亚洲在线| 国产呦萝稀缺另类资源| 亚洲一区二区在线观看视频| 国产精品护士白丝一区av| 久久网站最新地址| 91精品婷婷国产综合久久竹菊| 色哟哟一区二区| 成人国产精品免费| 国产成人自拍在线| 精品影院一区二区久久久| 午夜国产精品一区| 亚洲自拍偷拍网站| 一区二区三区在线不卡| 1区2区3区欧美| 久久精品一区二区三区av| 日韩一级片网站| 日韩视频免费观看高清完整版| 欧美日韩国产美女| 欧美乱妇一区二区三区不卡视频| 91福利在线导航| 日本精品裸体写真集在线观看| 91蜜桃婷婷狠狠久久综合9色| 成人黄色在线网站| 99精品视频在线观看免费| 成人av资源站| 91丨九色丨国产丨porny| 波多野结衣亚洲| 99re这里只有精品首页| 欧美一区二区视频网站| 日韩欧美不卡在线观看视频| 欧美一级久久久久久久大片| 欧美一区二区三区公司| 欧美电影免费观看完整版| 欧美zozo另类异族| 精品国产一区二区国模嫣然| 精品国产一区a| 久久久久97国产精华液好用吗| 国产亚洲欧美中文| 亚洲欧洲另类国产综合| 一区二区三区丝袜| 日韩福利电影在线观看| 久久av老司机精品网站导航| 国产九色sp调教91| 99久久国产综合精品女不卡| 欧美日韩综合在线免费观看| 欧美一区二区三区电影| 亚洲精品一区在线观看| 日本一区二区成人| 亚洲日本一区二区| 日韩黄色小视频| 黑人精品欧美一区二区蜜桃| 国产成人精品免费视频网站| 日本乱人伦aⅴ精品| 91 com成人网| 久久久久久久国产精品影院| 亚洲色图制服诱惑 | 激情五月激情综合网| 成人动漫av在线| 欧美专区亚洲专区| 日韩视频免费直播| 国产精品福利一区二区| 午夜电影一区二区三区| 国产成人在线色| 欧美天堂一区二区三区| 久久久久国产成人精品亚洲午夜| 亚洲精品水蜜桃| 久色婷婷小香蕉久久| 94-欧美-setu| 精品美女一区二区| 亚洲精品国产精品乱码不99| 久久99精品久久久久久国产越南 | 欧美日韩在线不卡| 久久久久国产一区二区三区四区| 国产精品一区二区91| 色综合久久综合中文综合网| 日韩免费视频线观看| 亚洲码国产岛国毛片在线| 毛片av一区二区| 91丨porny丨国产| 久久综合九色综合欧美亚洲| 一区二区三区精密机械公司| 国产精品影视天天线| 欧美酷刑日本凌虐凌虐| 亚洲欧洲日韩av| 国产一区二区女| 欧美一区二视频| 夜夜精品视频一区二区| 成人精品视频一区二区三区 | 91原创在线视频| 精品福利视频一区二区三区| 亚洲图片有声小说| 91免费看`日韩一区二区| 久久欧美一区二区| 久久精品99国产精品日本| 日本高清不卡一区| 4hu四虎永久在线影院成人| 国产91丝袜在线18| 欧美日韩aaa| 亚洲精品国产第一综合99久久| 国产suv一区二区三区88区| 欧美一区二视频| 午夜精品视频在线观看| 欧洲精品一区二区三区在线观看| 欧美激情一区不卡| 国产精品一级黄| 久久综合久久鬼色| 久草在线在线精品观看| 91精品国产91久久综合桃花| 亚洲一区二区三区四区不卡| 色综合久久久久| 亚洲伦理在线免费看| 99精品桃花视频在线观看| 中文字幕一区二区三中文字幕| 成人av资源站| 中文字幕在线免费不卡| 99在线精品一区二区三区| 中文字幕视频一区| 99久久国产综合色|国产精品| 综合久久久久久久| 色婷婷精品大在线视频| 亚洲精品美腿丝袜| 欧美日韩一卡二卡三卡| 日韩成人免费看| 日韩欧美成人一区二区| 国产原创一区二区| 中文乱码免费一区二区| av欧美精品.com| 亚洲国产精品久久不卡毛片 | 久久久久久99久久久精品网站| 国产剧情av麻豆香蕉精品| 国产精品热久久久久夜色精品三区| 成人高清在线视频| 夜夜精品视频一区二区| 欧美日本在线看| 久久99精品久久久久| 国产欧美日韩亚州综合| 欧美一级国产精品| 久久99精品久久久久久动态图| 国产视频在线观看一区二区三区| 成人黄色小视频| 香蕉影视欧美成人| 日韩欧美一区在线观看| 成人听书哪个软件好| 亚洲第一综合色| 久久精品视频网| 欧美视频在线一区二区三区 | 国产精品一区二区三区网站| 国产精品乱码久久久久久| 欧美日韩一本到| 国产精品亚洲午夜一区二区三区 |