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

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

?? des.cpp

?? 這個程序是用vc實現(xiàn)的des加密解密算法
?? CPP
字號:
#include "stdafx.h"
//////////////////////////////////////////////////////////////////////////
/*
    Provided by 黃衛(wèi)立,李謨?nèi)剩ご淦?    Email: hwlchina@126.com
	在程序中用bool表示位數(shù)據(jù)
*/
//////////////////////////////////////////////////////////////////////////

#include "memory.h"
#include "des.h"

//DES的初始置換IP表
const static char IP_Table[64] =
 {
	58, 50, 42, 34, 26, 18, 10, 2,
	60, 52, 44, 36, 28, 20, 12, 4,
	62, 54, 46, 38, 30, 22, 14, 6, 
	64, 56, 48, 40, 32, 24, 16, 8,
	57, 49, 41, 33, 25, 17,  9, 1,
	59, 51, 43, 35, 27, 19, 11, 3,
    61, 53, 45, 37, 29, 21, 13, 5,
    63, 55, 47, 39, 31, 23, 15, 7
};
//DES的IP逆置換表 
const static char IPR_Table[64] = 
{
	40, 8, 48, 16, 56, 24, 64, 32, 
	39, 7, 47, 15, 55, 23, 63, 31,
	38, 6, 46, 14, 54, 22, 62, 30,
  37, 5, 45, 13, 53, 21, 61, 29,
  36, 4, 44, 12, 52, 20, 60, 28,
  35, 3, 43, 11, 51, 19, 59, 27,
	34, 2, 42, 10, 50, 18, 58, 26,
	33, 1, 41,  9, 49, 17, 57, 25
};

//DES加密過程的選為表E
static const char E_Table[48] = {
	32, 1,  2,  3,  4,  5, 
	4,  5,  6,  7,  8,  9,
	8,  9, 10, 11, 12, 13,
	12, 13, 14, 15, 16, 17,
	16, 17, 18, 19, 20, 21,
  20, 21, 22, 23, 24, 25,
	24, 25, 26, 27, 28, 29,
	28, 29, 30, 31, 32, 1
};
// 32-bit permutation function P used on the output of the S-boxes 
const static char P_Table[32] = {
	16, 7, 20, 21,
	29, 12, 28, 17, 
	1,  15, 23, 26,
	5,  18, 31, 10,
	2,  8, 24, 14, 
	32, 27, 3,  9, 
	19, 13, 30, 6,
	22, 11, 4,  25
};
// 置換選擇表PC-1
const static char PC1_Table[56] = {
	57, 49, 41, 33, 25, 17,  9,  1, 58, 50, 42, 34, 26, 18,
	10,  2, 59, 51, 43, 35, 27, 19, 11,  3, 60, 52, 44, 36,
	63, 55, 47, 39, 31, 23, 15,  7, 62, 54, 46, 38, 30, 22,
	14,  6, 61, 53, 45, 37, 29, 21, 13,  5, 28, 20, 12,  4
};
//置換選擇表PC-2 
const static char PC2_Table[48] = {
	 14, 17, 11, 24,  1,  5, 
	 3, 28, 15,  6, 21, 10,
	 23, 19, 12,  4, 26,  8, 
	 16,  7, 27, 20, 13,  2,
	 41, 52, 31, 37, 47, 55, 
	 30, 40, 51, 45, 33, 48,
	 44, 49, 39, 56, 34, 53, 
	 46, 42, 50, 36, 29, 32
};
//循環(huán)左移運算表
const static char LOOP_Table[16] = {
//1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16
	1,1,2,2,2,2,2,2,1, 2, 2, 2, 2, 2, 2,1
};

//S盒運算 
const static char S_Box[8][4][16] = {
//盒S1 
	14,	 4,	13,	 1,  2, 15, 11,  8,  3, 10,  6, 12,  5,  9,  0,  7,
	 0, 15,  7,  4, 14,  2, 13,  1, 10,  6, 12, 11,  9,  5,  3,  8,
	 4,  1, 14,  8, 13,  6,  2, 11, 15, 12,  9,  7,  3, 10,  5,  0,
  15, 12,  8,  2,  4,  9,  1,  7,  5, 11,  3, 14, 10,  0,  6, 13,
//盒S2 
    15,  1,  8, 14,  6, 11,  3,  4,  9,  7,  2, 13, 12,  0,  5, 10,
	 3, 13,  4,  7, 15,  2,  8, 14, 12,  0,  1, 10,  6,  9, 11,  5,
	 0, 14,  7, 11, 10,  4, 13,  1,  5,  8, 12,  6,  9,  3,  2, 15,
    13,  8, 10,  1,  3, 15,  4,  2, 11,  6,  7, 12,  0,  5, 14,  9,
//盒S3 
  10,  0,  9, 14,  6,  3, 15,  5,  1, 13, 12,  7, 11,  4,  2,  8,
	13,  7,  0,  9,  3,  4,  6, 10,  2,  8,  5, 14, 12, 11, 15,  1,
	13,  6,  4,  9,  8, 15,  3,  0, 11,  1,  2, 12,  5, 10, 14,  7,
  1, 10, 13,  0,  6,  9,  8,  7,  4, 15, 14,  3, 11,  5,  2,  12,
//盒S4 
  7, 13, 14,  3,  0,  6,  9, 10,  1,  2,  8,  5, 11, 12,  4, 15,
	13,  8, 11,  5,  6, 15,  0,  3,  4,  7,  2, 12,  1, 10, 14,  9,
	10,  6,  9,  0, 12, 11,  7, 13, 15,  1,  3, 14,  5,  2,  8,  4,
  3, 15,  0,  6, 10,  1, 13,  8,  9,  4,  5, 11, 12,  7,  2, 14,
//盒S5 
  2, 12,  4,  1,  7, 10, 11,  6,  8,  5,  3, 15, 13,  0, 14,  9,
	14, 11,  2, 12,  4,  7, 13,  1,  5,  0, 15, 10,  3,  9,  8,  6,
	4,  2,  1, 11, 10, 13,  7,  8, 15,  9, 12,  5,  6,  3,  0, 14,
  11,  8, 12,  7,  1, 14,  2, 13,  6, 15,  0,  9, 10,  4,  5,  3,
//盒S6 
  12,  1, 10, 15,  9,  2,  6,  8,  0, 13,  3,  4, 14,  7,  5, 11,
	10, 15,  4,  2,  7, 12,  9,  5,  6,  1, 13, 14,  0, 11,  3,  8,
	9, 14, 15,  5,  2,  8, 12,  3,  7,  0,  4, 10,  1, 13, 11,  6,
  4,  3,  2, 12,  9,  5, 15, 10, 11, 14,  1,  7,  6,  0,  8, 13,
//盒S7 
  4, 11,  2, 14, 15,  0,  8, 13,  3, 12,  9,  7,  5, 10,  6,  1,
	13,  0, 11,  7,  4,  9,  1, 10, 14,  3,  5, 12,  2, 15,  8,  6,
	1,  4, 11, 13, 12,  3,  7, 14, 10, 15,  6,  8,  0,  5,  9,  2,
  6, 11, 13,  8,  1,  4, 10,  7,  9,  5,  0, 15, 14,  2,  3, 12,
//盒S8 
   13,  2,  8,  4,  6, 15, 11,  1, 10,  9,  3, 14,  5,  0, 12,  7,
	 1, 15, 13,  8, 10,  3,  7,  4, 12,  5,  6, 11,  0, 14,  9,  2,
	 7, 11,  4,  1,  9, 12, 14,  2,  0,  6, 10, 13, 15,  3,  5,  8,
   2,  1, 14,  7,  4, 10,  8, 13, 15, 12,  9,  0,  3,  5,  6, 11
};


typedef bool   (*PSubKey)[16][48]; //這里用bool來表示 一個位

static void DES(char Out[8], char In[8], const PSubKey pSubKey, bool Type);//標準DES加/解密

static void SetKey(const char* Key, int len);  // 設(shè)置密鑰 key 字符組  len是key字符組的長度

static void SetSubKey(PSubKey pSubKey, const char Key[8]);// 設(shè)置子密鑰

static void F_func(bool In[32], const bool Ki[48]);// f 函數(shù)

static void S_func(bool Out[32], const bool In[48]);// S 盒代替

static void Transform(bool *Out, bool *In, const char *Table, int len);// 變換

static void Xor(bool *InA, const bool *InB, int len);// 異或

static void RotateL(bool *In, int len, int loop);// 循環(huán)左移

static void ByteToBit(bool *Out, const char *In, int bits);// 字節(jié)組轉(zhuǎn)換成位組

static void BitToByte(char *Out, const bool *In, int bits);// 位組轉(zhuǎn)換成字節(jié)組

//////////////////////////////////////////////////////////////////////////

static bool SubKey[2][16][48];// 16圈子密鑰

static bool Is3DES;// 3次DES標志

static char Tmp[256], deskey[16];

/*
主體加密解密函數(shù)
*/
bool Des_Go(char *Out, char *In, long datalen, const char *Key, int keylen, bool Type)
{
    if( !( Out && In && Key && (datalen=(datalen+7)&0xfffffff8) ) ) 
		return false;
	SetKey(Key, keylen);
	if( !Is3DES ) {   // 1次DES
		for(long i=0,j=datalen>>3; i<j; ++i,Out+=8,In+=8)
			DES(Out, In, &SubKey[0], Type);
	}
	 else{   // 3次DES 加密:加(key0)-解(key1)-加(key0) 解密::解(key0)-加(key1)-解(key0)
		for(long i=0,j=datalen>>3; i<j; ++i,Out+=8,In+=8) {
			DES(Out, In,  &SubKey[0], Type);
			DES(Out, Out, &SubKey[1], !Type);
			DES(Out, Out, &SubKey[0], Type);
		}
	}
	return true;
}

/*
 SetKeyz這個函數(shù)用來設(shè)置密匙,當輸入的密匙長度超過16個字節(jié)時只截取前16字節(jié)
*/
void SetKey(const char* Key, int len)
{
	//對密匙存儲空間進行初始化
	memset(deskey, 0, 16);
	//當密匙的長度大于16時截取前16字節(jié),否則去實際字符長度
	memcpy(deskey, Key, len>16?16:len);
    //設(shè)置子密匙
	SetSubKey(&SubKey[0], &deskey[0]);
	//判斷加解密的數(shù)據(jù)是否大于8而要進行三次DE加解密,如果len大于8對密匙空間的后八位進行處理
	Is3DES = len>8 ? (SetSubKey(&SubKey[1], &deskey[8]), true) : false;
}

//每八位一組的DES運算
void DES(char Out[8], char In[8], const PSubKey pSubKey, bool Type)
{
    static bool M[64], tmp[32], *Li=&M[0], *Ri=&M[32];
    ByteToBit(M, In, 64);
    Transform(M, M, IP_Table, 64);
    if( Type == ENCRYPT ){
		//進行16輪迭代進行加密
        for(int i=0; i<16; ++i) {
            memcpy(tmp, Ri, 32);
            F_func(Ri, (*pSubKey)[i]);
            Xor(Ri, Li, 32);
            memcpy(Li, tmp, 32);
        }
    }else{
		//進行16輪逆迭代進行解密
        for(int i=15; i>=0; --i) {
            memcpy(tmp, Li, 32);
            F_func(Li, (*pSubKey)[i]);
            Xor(Li, Ri, 32);
            memcpy(Ri, tmp, 32);
        }
	}
    Transform(M, M, IPR_Table, 64);
    BitToByte(Out, M, 64);
}


void SetSubKey(PSubKey pSubKey, const char Key[8])
{   //
    static bool K[64], *KL=&K[0], *KR=&K[28];
    //把字節(jié)轉(zhuǎn)化成位數(shù)據(jù)
	ByteToBit(K, Key, 64);
	//通過PC-1置換選擇表進行置換
    Transform(K, K, PC1_Table, 56);
    //進行16輪的迭代
	for(int i=0; i<16; ++i) {
        //對左部的28位進行 左循環(huán)
        RotateL(KL, 28, LOOP_Table[i]);
        //對右部的28位進行 左循環(huán)
        RotateL(KR, 28, LOOP_Table[i]);
        //根據(jù) PC-2置換選擇表進行置換
        Transform((*pSubKey)[i], K, PC2_Table, 48);
        
    }
}

//進行F函數(shù)運算
void F_func(bool In[32], const bool Ki[48])
{
    static bool MR[48];
    Transform(MR, In, E_Table, 48);
    Xor(MR, Ki, 48);
    S_func(In, MR);
    Transform(In, In, P_Table, 32);
}

//進行S函數(shù)運算
void S_func(bool Out[32], const bool In[48])
{
    for(char i=0,j,k; i<8; ++i,In+=6,Out+=4) {
        j = (In[0]<<1) + In[5];
        k = (In[1]<<3) + (In[2]<<2) + (In[3]<<1) + In[4];
		ByteToBit(Out, &S_Box[i][j][k], 4);
    }
}


//通過指定的置換表進行數(shù)據(jù)置換
void Transform(bool *Out, bool *In, const char *Table, int len)
{
    for(int i=0; i<len; ++i)
        Tmp[i] = In[ Table[i]-1 ];
    memcpy(Out, Tmp, len);
}


//進行異或運算
void Xor(bool *InA, const bool *InB, int len)
{
    for(int i=0; i<len; ++i)
        InA[i] ^= InB[i];
}

//進行循環(huán)左移運算
void RotateL(bool *In, int len, int loop)
{
    memcpy(Tmp, In, loop);  //獲取In字符組的前l(fā)oop個字符
    memcpy(In, In+loop, len-loop);//把In字符數(shù)組的后len-loop移到數(shù)組的開頭
    memcpy(In+len-loop, Tmp, loop);//把loop個字符補到末尾
}

//把字符轉(zhuǎn)化為位
void ByteToBit(bool *Out, const char *In, int bits)
{
   
    for(int i=0; i<bits; ++i)
        Out[i] = (In[i>>3]>>(i&7)) & 1;//通過移位獲取每一個字符的第一個位的值
}

//把位轉(zhuǎn)化為數(shù)組
void BitToByte(char *Out, const bool *In, int bits)
{
    memset(Out, 0, bits>>3);
    for(int i=0; i<bits; ++i)  //沒八個位和并為一個字符
        Out[i>>3] |= In[i]<<(i&7);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区成人| 99re这里只有精品首页| 在线播放国产精品二区一二区四区| 欧美丰满少妇xxxbbb| 久久精品亚洲乱码伦伦中文| 亚洲专区一二三| 成人小视频在线| 日韩网站在线看片你懂的| 亚洲精品视频免费看| 国产一区二区三区精品欧美日韩一区二区三区| 成人av电影免费在线播放| 欧美一区二区三级| 一区二区激情小说| av在线这里只有精品| 337p日本欧洲亚洲大胆色噜噜| 亚洲午夜精品17c| 一本到高清视频免费精品| 精品免费日韩av| 日本女优在线视频一区二区| 色偷偷成人一区二区三区91 | 国产69精品久久99不卡| 欧美福利一区二区| 亚洲国产精品精华液网站| 99国产精品国产精品久久| 欧美国产一区在线| 国产麻豆精品95视频| 精品国产乱子伦一区| 日本不卡123| 欧美一区二区视频在线观看2022 | 久久美女高清视频 | 国产一区二区看久久| 日韩免费一区二区三区在线播放| 一区2区3区在线看| 91香蕉视频黄| 亚洲乱码国产乱码精品精小说| 92国产精品观看| 亚洲天堂精品在线观看| 成人午夜精品在线| 亚洲欧洲日韩女同| 欧美系列一区二区| 亚洲三级电影网站| 99久久国产综合精品色伊| 一区免费观看视频| 91成人免费电影| 亚洲成av人片在线观看无码| 在线观看av不卡| 夜夜嗨av一区二区三区四季av| 91猫先生在线| 亚洲一区二区av电影| 日本韩国欧美在线| 日韩精品一二三| 精品久久久久香蕉网| 国产精品综合久久| 国产精品嫩草影院av蜜臀| 91在线一区二区| 亚洲国产精品嫩草影院| 日韩欧美的一区| 国产精品一区三区| 亚洲人午夜精品天堂一二香蕉| 日本精品视频一区二区三区| 天天亚洲美女在线视频| 欧美一级一区二区| 国产成人精品网址| 一区二区在线观看免费视频播放| 精品视频一区 二区 三区| 美国三级日本三级久久99| 国产偷国产偷亚洲高清人白洁| 99精品视频一区二区| 亚洲综合视频在线| 欧美α欧美αv大片| 成人在线综合网| jizz一区二区| 日韩不卡一区二区三区| 久久久久国产成人精品亚洲午夜 | 卡一卡二国产精品| 国产精品成人一区二区艾草| 欧美久久久久中文字幕| 国产高清无密码一区二区三区| 亚洲精品视频一区二区| 精品日韩在线观看| 欧美亚一区二区| 国产精华液一区二区三区| 亚洲精品欧美激情| 久久精品一级爱片| 欧美一区二区三区四区久久| 成人美女视频在线观看| 麻豆精品久久精品色综合| 亚洲欧美一区二区三区极速播放| 精品免费日韩av| 欧美猛男男办公室激情| 99re在线视频这里只有精品| 精品影院一区二区久久久| 尤物av一区二区| 亚洲国产高清不卡| 精品国产一区二区三区久久影院| 在线观看欧美日本| 99精品久久久久久| 粉嫩av亚洲一区二区图片| 蜜桃视频在线观看一区二区| 亚洲第一综合色| 一区二区三区资源| 欧美激情在线一区二区| 亚洲精品一线二线三线无人区| 欧美日韩不卡在线| 欧美探花视频资源| 色一情一伦一子一伦一区| 日韩免费在线观看| 91精品国产丝袜白色高跟鞋| 欧美在线观看一二区| 色婷婷综合激情| 99re这里只有精品首页| 粉嫩一区二区三区性色av| 国内精品视频666| 理论片日本一区| 日本不卡一区二区三区| 偷拍亚洲欧洲综合| 亚洲国产成人av| 天天做天天摸天天爽国产一区| 夜夜揉揉日日人人青青一国产精品| 亚洲欧洲一区二区三区| 中文字幕一区二区视频| 中文字幕在线观看不卡| 亚洲精品一卡二卡| 一级中文字幕一区二区| 亚洲高清免费观看| 日日摸夜夜添夜夜添精品视频| 日本不卡一二三| 久久激五月天综合精品| 国产伦精品一区二区三区免费迷| 韩国一区二区三区| 成人美女视频在线观看18| 99热99精品| 欧美日韩免费不卡视频一区二区三区| 欧美精品一级二级| 日韩欧美123| 久久九九99视频| 亚洲色图清纯唯美| 日韩精品视频网| 国产在线看一区| voyeur盗摄精品| 欧美无人高清视频在线观看| 欧美美女一区二区| 一区二区免费视频| 久久精品国产久精国产| 成人做爰69片免费看网站| 不卡欧美aaaaa| 欧美精品在线观看播放| 久久毛片高清国产| 一区二区三区日本| 美女一区二区视频| www.99精品| 欧美一区二区在线不卡| 国产精品入口麻豆九色| 亚洲一二三专区| 国产揄拍国内精品对白| 91麻豆swag| 精品国产乱码久久久久久久久| 国产精品丝袜久久久久久app| 亚洲一区国产视频| 国产精品乡下勾搭老头1| 日本久久一区二区三区| 日韩久久久精品| 一区二区不卡在线播放 | 成人一级视频在线观看| 欧美色老头old∨ideo| 久久亚洲一级片| 亚洲午夜免费福利视频| 国产a视频精品免费观看| 欧美三级中文字幕| 国产日韩精品一区二区三区| 偷拍日韩校园综合在线| aaa亚洲精品一二三区| 精品国一区二区三区| 亚洲成人1区2区| 99久久综合精品| 免费看欧美美女黄的网站| 色域天天综合网| 日本一区二区综合亚洲| 久久精品999| 欧美日韩国产美| 亚洲柠檬福利资源导航| 国产精品一区2区| 日韩欧美国产一区在线观看| 亚洲国产综合人成综合网站| 成人的网站免费观看| 精品国产乱码久久久久久免费| 天天av天天翘天天综合网色鬼国产| 91同城在线观看| 中文字幕精品—区二区四季| 国模少妇一区二区三区| 日韩一区二区三区精品视频| 无码av中文一区二区三区桃花岛| 日本伦理一区二区| 亚洲免费毛片网站| 一本一本久久a久久精品综合麻豆| 久久久久久电影| 国产白丝精品91爽爽久久| 日韩精品一区在线观看| 美国毛片一区二区三区| 日韩欧美二区三区|