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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? mydes.cpp

?? Visual C++ 實現DES算法
?? CPP
字號:
// MyDes.cpp : implementation file
//

#include "stdafx.h"
#include "DES.h"
#include "MyDes.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif


/////////////////////////////////////////////////////////////////////////////
// MyDes

IMPLEMENT_DYNCREATE(CMyDes, CCmdTarget)

CMyDes::CMyDes()
{
}

CMyDes::~CMyDes()
{
}


BEGIN_MESSAGE_MAP(CMyDes, CCmdTarget)
	//{{AFX_MSG_MAP(MyDes)
		// NOTE - the ClassWizard will add and remove mapping macros here.
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// MyDes message handlers



CString CMyDes::DecryStrHex(CString StrHex,CString Key)
{
	CString Str,Temp;
	int I,StrHexLen;
	StrHexLen = strlen(StrHex);
	Str.Empty();
	for (I=0;I<(StrHexLen / 2);I++)
	{
		Temp.Empty();
		Temp = Temp +StrHex[(I * 2)];
		Temp = Temp +StrHex[(I * 2+1)];
		
		Str = Str + (char)(HexToByte(Temp));
	}

  return DecryStr(Str, Key);


}

CString CMyDes::DecryStr(CString Str, CString Key)
{ 
	BYTE KeyByte[8],StrByte[8],OutByte[8];
	CString StrResult;
	
	int J,I;
	//不足八個字符的密碼補齊
	while (strlen(Key)<8) {
		Key = Key + ' ';
		};
	for (J=0;J<8;J++)
		KeyByte[J] = Key[J];
	makeKey(KeyByte,subKey);
	
	for (I = 0; I<(int)(strlen(Str))/8;I++)
	{
		for (J=0;J<8;J++)
			StrByte[J] = Str[I * 8 + J];
		desData(dmDecry, StrByte, OutByte);
		for (J=0;J<8;J++) 
		StrResult = StrResult + (char)OutByte[J];

	}
	

	return StrResult;

}

void CMyDes::makeKey(BYTE inkey[], KEYBYTE outkey[])
{
	//左移次數的規定
	const BYTE bitDisplace[16] = { 1,1,2,2, 2,2,2,2, 1,2,2,2, 2,2,2,1 };
	BYTE outData56[7],outkey56[7];
	BYTE key28l[4],key28r[4];
	int  j,i;

	permutationChoose1(inkey,outData56);

	key28l[0] = outData56[0] >> 4;
	key28l[1] = (outData56[0] << 4) | (outData56[1] >> 4);
	key28l[2] = (outData56[1] << 4) | (outData56[2] >> 4);
	key28l[3] = (outData56[2] << 4) | (outData56[3] >> 4);
	key28r[0] = outData56[3] & 0x0f;
	key28r[1] = outData56[4];
	key28r[2] = outData56[5];
	key28r[3] = outData56[6];
	//16輪迭代產成16個子密碼
	for (j = 0 ;j<16; j++)
	{
		i = j;
		cycleMove(key28l, bitDisplace[i]);
		cycleMove(key28r, bitDisplace[i]);
		outkey56[0] = (key28l[0] << 4) | (key28l[1] >> 4);
		outkey56[1] = (key28l[1] << 4) | (key28l[2] >> 4);
		outkey56[2] = (key28l[2] << 4) | (key28l[3] >> 4);
		outkey56[3] = (key28l[3] << 4) | (key28r[0]);
		outkey56[4] = key28r[1];
		outkey56[5] = key28r[2];
		outkey56[6] = key28r[3];
		permutationChoose2(outkey56, outkey[i]);
	};

}

void CMyDes::permutationChoose1(BYTE inData[], BYTE outData[])
{
	int i;
	for (i = 0 ; i<7; i++)
		outData[i] = 0;
	
	for (i = 0 ; i<56; i++)
	{
		if ((inData[BitPMC1[i] >> 3] & (1 << (7-(BitPMC1[i] & 7)))) !=0) 
			outData[i >> 3] = outData[i >> 3] | (1 << (7-(i & 7)));	
 	}
}

void CMyDes::permutationChoose2(BYTE inData[], BYTE outData[])
{
	int i;
	for (i = 0 ; i<6; i++) outData[i] = 0;
	
	for (i = 0 ; i<48; i++)
	{
		if ((inData[BitPMC2[i] >> 3] & (1 << (7-(BitPMC2[i] & 7)))) !=0) 
			outData[i >> 3] = outData[i >> 3] | (1 << (7-(i & 7)));	
 	}
}

void CMyDes::cycleMove(BYTE inData[], BYTE bitMove)
{
	for (int i = 0; i<bitMove;i++) 
	{
		inData[0] = (inData[0] << 1) | (inData[1] >> 7);
		inData[1] = (inData[1] << 1) | (inData[2] >> 7);
		inData[2] = (inData[2] << 1) | (inData[3] >> 7);
		inData[3] = (inData[3] << 1) | ((inData[0] & 0x10) >> 4);
		inData[0] = (inData[0] & 0x0f);
	};

}


void CMyDes::initPermutation(BYTE inData[])
{
	BYTE newData[8];
	int i;
	for ( i = 0 ; i<8 ;i++ ) newData[i] = 0; 
	for (i = 0; i<64; i++)
		if ((inData[BitIP[i] >> 3] & (1 << (7- (BitIP[i] & 0x07)))) != 0)
			newData[i >> 3] = newData[i >> 3] | (1 << (7-(i & 0x07)));
	for ( i = 0 ; i<8 ;i++ ) inData[i] = newData[i];

}

void CMyDes::encry(BYTE inData[], BYTE subKey[], BYTE outData[])
{
	BYTE outBuf[6],buf[8];
	int i;

	expand(inData, outBuf);
	for (i = 0;i<6;i++)  outBuf[i] = outBuf[i] ^ subKey[i];
	buf[0] = outBuf[0] >> 2;
	buf[1] = ((outBuf[0] & 0x03) << 4) | (outBuf[1] >> 4);
	buf[2] = ((outBuf[1] & 0x0f) << 2) | (outBuf[2] >> 6);
	buf[3] = outBuf[2] & 0x3f;
	buf[4] = outBuf[3] >> 2;
	buf[5] = ((outBuf[3] & 0x03) << 4) | (outBuf[4] >> 4);
	buf[6] = ((outBuf[4] & 0x0f) << 2) | (outBuf[5] >> 6);
	buf[7] = outBuf[5] & 0x3f;
	for (i = 0;i<8;i++)  buf[i] = si(i, buf[i]);
	for (i = 0;i<4;i++)  outBuf[i] = (buf[i*2] << 4) | buf[i*2+1];
	permutation(outBuf);
	for (i = 0;i<4;i++)  outData[i] = outBuf[i];

}

void CMyDes::expand(BYTE inData[], BYTE outData[])
{
	int i;
	for (i = 0; i<6;i++) outData[i] = 0;
	for (i = 0; i<48;i++) 
		if ((inData[BitExp[i] >> 3] & (1 << (7-(BitExp[i] & 0x07)))) != 0) 
			outData[i >> 3] = outData[i >> 3] | (1 << (7-(i & 0x07)));

}

BYTE CMyDes::si(BYTE s, BYTE inByte)
{
	BYTE c;
	c = (inByte & 0x20) | ((inByte & 0x1e) >> 1) | ((inByte & 0x01) << 4);
	return  (sBox[s][c] & 0x0f);

}

void CMyDes::permutation(BYTE inData[])
{
	BYTE newData[8];
	BYTE bTemp[8];
	int i;
	for (i = 0;i<8;i++)	newData[i] =0;
	for (i = 0;i<6;i++) bTemp[i] = inData[i];
	bTemp[6] = 0;
	bTemp[7] = 0;
	for (i = 0;i<64;i++) 
	{

		if ((bTemp[BitIP[i] >> 3] & (1 << (7- (BitIP[i] & 0x07)))) != 0 )
			newData[i >> 3] = newData[i >> 3] | (1 << (7-(i & 0x07)));

	};
	for (i = 0;i<8;i++)	 inData[i] = newData[i];

}

void CMyDes::conversePermutation(BYTE inData[])
{
	BYTE newData[8];
	int i;
	for (i=0;i<8;i++) newData[i] = 0;
	for (i=0;i<64;i++) 
		if ((inData[BitCP[i] >> 3] & (1 << (7-(BitCP[i] & 0x07)))) != 0) 
			newData[i >> 3] = newData[i >> 3] | (1 << (7-(i & 0x07)));
	for (i=0;i<8;i++) inData[i] = newData[i];

}

void CMyDes::desData(DESMODE desMode, BYTE inData[], BYTE outData[])
{
	int i,j;
	BYTE temp[4],buf[4];
	BYTE bTemp[8];
	
	for (i=0;i<8;i++) outData[i] = inData[i];

	for (i=0;i<8;i++) bTemp[i] = outData[i];

	//初始變換
	initPermutation(outData);

	for (i=0;i<8;i++) bTemp[i] = outData[i];

	if (desMode == dmEncry) 
	{
		for (i=0;i<16;i++)
		{
			for (j=0;j<4;j++) temp[j] = outData[j];
			for (j=0;j<4;j++) outData[j] = outData[j + 4];
			encry(outData, subKey[i], buf);
			for (int k=0;k<8;k++) bTemp[k] = outData[k];

			for (j=0;j<4;j++) outData[j + 4] = temp[j] ^ buf[j];
		}
		for (j=0;j<4;j++) temp[j] = outData[j + 4];
		for (j=0;j<4;j++) outData[j + 4] = outData[j];
		for (j=0;j<4;j++) outData[j] = temp[j];

	}
	else if (desMode == dmDecry)
	{
		for(i=15;i>=0;i--)
		{
			for (j=0;j<4;j++) temp[j] = outData[j];
			for (j=0;j<4;j++) outData[j] = outData[j + 4];
			encry(outData, subKey[i], buf);
			for (j=0;j<4;j++) outData[j + 4] = temp[j] ^ buf[j];
		}
		    
		for (j=0;j<4;j++) temp[j] = outData[j + 4];
		for (j=0;j<4;j++) outData[j + 4] = outData[j];
		for (j=0;j<4;j++) outData[j] = temp[j];

	}
	conversePermutation(outData);

}

CString CMyDes::EncryStr(CString Str, CString Key)
{
	BYTE KeyByte[8]={0},StrByte[8]={0},OutByte[8]={0};
	int J,I;
	int Strlength;
	
	//if ((Strlength > 0) && (Str[Strlength]) == 0) return "";
	while (strlen(Key) < 8)  Key = Key + ' ' ;
	while (strlen(Str) % 8 != 0)  Str = Str +' ';
	Strlength = (int)strlen(Str);
	
	for (J=0;J<8;J++)  KeyByte[J] = (Key[J]);
	makeKey(KeyByte, subKey);

	CString StrResult;
	StrResult.Empty();

	for (I = 0;I< Strlength/8;I++) 
	{
		for (J=0;J<8;J++) 
			StrByte[J] = Str[I * 8 + J];
		desData(dmEncry, StrByte, OutByte);
		for (J=0;J<8;J++) 
			StrResult = StrResult+(char)OutByte[J];
	};

	return StrResult;

}

CString CMyDes::EncryStrHex(CString Str, CString Key)
{
	int I;
	  
	CString TempResult,StrResult;
	BYTE Temp;
	TempResult = EncryStr(Str, Key);
	StrResult.Empty();
	for (I=0;(I<(int)strlen(TempResult));I++)
	{
		Temp = TempResult[I];
		
		StrResult = StrResult + ByteToHex(Temp);	
	}

  return StrResult;

}

CString CMyDes::ByteToHex(BYTE inByte)
{
	CString ResultStr;
	BYTE bTemp;
	int iTemp;
	ResultStr.Empty();
	bTemp = inByte;
	bTemp = bTemp & 0x0f;
	iTemp = (int)bTemp;
	switch (bTemp)
	{
	case 10:
		ResultStr = "A";
		break;
	case 11:
		ResultStr = "B";
		break;
	case 12:
		ResultStr = "C";
		break;
	case 13:
		ResultStr = "D";
		break;
	case 14:
		ResultStr = "E";
		break;
	case 15:
		ResultStr = "F";
		break;
	default:
		ResultStr = (char)(bTemp+'0');
	};

	bTemp = inByte>>4;
	switch (bTemp)
	{
	case 10:
		ResultStr =  "A"+ResultStr ;
		break;
	case 11:
		ResultStr = "B"+ResultStr  ;
		break;
	case 12:
		ResultStr = "C"+ResultStr  ;
		break;
	case 13:
		ResultStr = "D"+ResultStr  ;
		break;
	case 14:
		ResultStr = "E"+ResultStr  ;
		break;
	case 15:
		ResultStr = "F"+ResultStr  ;
		break;
	default:
		ResultStr =  (char)(bTemp+'0')+ResultStr ;
	};
	
	return ResultStr;



}

BYTE CMyDes::HexToByte(CString inHex)
{
	BYTE bTemp,bTempH,bTempL;
	bTempH = inHex[0];
	bTempL = inHex[1];
	if ((bTempL>='A') && (bTempL<='F')) 
		bTempL = bTempL-'A'+10;
	if ((bTempL>='0') && (bTempL<='9')) 
		bTempL = bTempL-'0';

	if ((bTempH>='A') && (bTempH<='F')) 
		bTempH = bTempH-'A'+10;
	if ((bTempH>='0') && (bTempH<='9')) 
		bTempH = bTempH-'0';
	bTemp = (bTempH<<4) | bTempL;
	return bTemp;

}

CString CMyDes::BitToStr(BYTE inData)
{
	CString ResultStr;
	BYTE bTemp;
	ResultStr.Empty();
	for (int i=7; i>=0; i--)
	{
		bTemp = (inData>>i) & 1;
		if (bTemp==0)
			ResultStr = ResultStr + '0';
		else
			ResultStr = ResultStr + '1';

	
	}
	return ResultStr;
	

}

CString CMyDes::ByteToStr(BYTE inData[], int iLength)
{
	CString ResultStr;
	ResultStr.Empty();
	int i;
	for (i=0; i<iLength; i++)
	{
		ResultStr = ResultStr + BitToStr(inData[i]);
	}
	return ResultStr;

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精选免费视频| 亚洲欧洲色图综合| 一区二区三区蜜桃| 国内精品伊人久久久久av影院 | 老汉av免费一区二区三区 | 精品国产区一区| 亚洲国产成人高清精品| 成人丝袜视频网| 精品99久久久久久| 日韩国产精品91| 欧美综合欧美视频| 国产精品久久久久婷婷| 国产一区二区伦理| 91麻豆精品国产91久久久资源速度| 日韩一区在线看| 成人激情动漫在线观看| 亚洲精品一区二区在线观看| 天堂蜜桃91精品| 欧美色图第一页| 亚洲综合丝袜美腿| 色诱视频网站一区| 日韩久久一区二区| 粉嫩久久99精品久久久久久夜| 精品成人佐山爱一区二区| 日本女人一区二区三区| 精品视频999| 亚洲网友自拍偷拍| 欧美性感一类影片在线播放| 最新日韩av在线| av一区二区三区黑人| 中文成人综合网| 国产性天天综合网| 精品国产免费一区二区三区四区| 亚洲不卡一区二区三区| 麻豆91精品视频| av中文字幕一区| 国产精品乱码人人做人人爱 | 中文字幕免费在线观看视频一区| 精品一区二区影视| 精品国产乱码久久久久久浪潮| 麻豆国产欧美一区二区三区| 日韩免费观看高清完整版在线观看| 亚洲成人动漫精品| 欧美电影在哪看比较好| 日日夜夜精品视频免费| 欧美一级生活片| 久久电影国产免费久久电影| 久久综合色鬼综合色| 国产真实乱偷精品视频免| 久久久av毛片精品| 国产精品综合av一区二区国产馆| 久久精品一级爱片| 成人做爰69片免费看网站| 国产精品国产三级国产普通话蜜臀 | 亚洲影视在线观看| 国产美女av一区二区三区| 日韩电影网1区2区| 国产亚洲一二三区| 亚洲高清免费视频| 91精品国产综合久久久久| 免费成人av在线| 精品国产髙清在线看国产毛片| 久久国产夜色精品鲁鲁99| 精品电影一区二区三区| 国产iv一区二区三区| 成人免费在线视频观看| 91久久精品一区二区三| 午夜天堂影视香蕉久久| 欧美tk丨vk视频| 成人高清av在线| 亚洲综合视频在线| 日韩精品一区二区三区中文不卡 | 国产裸体歌舞团一区二区| 中文av一区二区| 91成人在线观看喷潮| 免费黄网站欧美| 中文乱码免费一区二区| 欧美性色黄大片| 久热成人在线视频| 国产精品视频免费| 欧美挠脚心视频网站| 国内精品伊人久久久久av影院| 国产精品另类一区| 欧美日韩国产综合视频在线观看| 蜜桃精品视频在线观看| 中文字幕五月欧美| 欧美一级日韩免费不卡| 播五月开心婷婷综合| 日韩一区欧美二区| 国产精品无遮挡| 欧美美女一区二区| 国产99久久久国产精品免费看 | 国产日韩高清在线| 欧美自拍偷拍午夜视频| 国产一区 二区 三区一级| 亚洲品质自拍视频| 精品久久人人做人人爽| 91蜜桃视频在线| 国产一区啦啦啦在线观看| 一区二区三区国产豹纹内裤在线| 欧美草草影院在线视频| av一区二区不卡| 精品在线观看视频| 一区二区成人在线观看| 久久久不卡影院| 91 com成人网| 99国产精品一区| 韩国理伦片一区二区三区在线播放| 亚洲色图制服诱惑| 2022国产精品视频| 欧美日韩国产综合草草| 成人av网址在线观看| 久久成人免费电影| 亚洲一区二区不卡免费| 亚洲国产高清在线观看视频| 91精品国产色综合久久久蜜香臀| 成人国产精品视频| 麻豆精品久久久| 亚洲 欧美综合在线网络| 国产精品色哟哟| 精品久久久久久无| 欧美久久久一区| 在线视频你懂得一区二区三区| 国产999精品久久久久久绿帽| 免费观看91视频大全| 亚洲第一福利一区| 综合欧美亚洲日本| 国产婷婷一区二区| 精品日本一线二线三线不卡| 精品视频1区2区3区| 色婷婷久久久亚洲一区二区三区| 丁香婷婷综合激情五月色| 国产在线播放一区三区四| 天天色综合成人网| 激情综合网最新| 日韩av电影一区| 五月综合激情日本mⅴ| 一区二区欧美精品| 亚洲欧洲精品一区二区精品久久久| 久久久影视传媒| 久久一区二区三区四区| 日韩免费电影一区| 欧美一区二区三区在| 欧美日韩国产在线播放网站| 欧美性色综合网| 欧美少妇一区二区| 色乱码一区二区三区88| 91在线精品一区二区三区| 成人国产精品免费观看动漫| 粉嫩一区二区三区性色av| 国产成人av电影在线播放| 国产精品资源在线| 国产一区二区剧情av在线| 国产在线不卡一卡二卡三卡四卡| 蜜桃av噜噜一区| 美女在线视频一区| 狠狠色丁香婷婷综合| 国产在线不卡一卡二卡三卡四卡| 国产综合色产在线精品| 国产精品一区一区三区| 国产美女精品在线| 国产成人免费视频网站高清观看视频| 国产自产2019最新不卡| 国产在线国偷精品免费看| 国产成人免费xxxxxxxx| 成人免费高清在线观看| 成人午夜短视频| a美女胸又www黄视频久久| www..com久久爱| 色综合色综合色综合色综合色综合 | 午夜电影一区二区三区| 日本不卡123| 精品夜夜嗨av一区二区三区| 国产精品夜夜爽| 成人av手机在线观看| 在线观看免费亚洲| 欧美精品丝袜中出| 精品免费视频一区二区| 国产精品无码永久免费888| 亚洲精品欧美激情| 天天影视涩香欲综合网| 国产原创一区二区| av电影在线观看不卡| 色婷婷av一区二区三区gif| 欧美日韩国产成人在线免费| 3d成人动漫网站| 欧美精品一区二区高清在线观看| 国产欧美日韩亚州综合 | 久久一夜天堂av一区二区三区| 国产区在线观看成人精品 | 久久久久国色av免费看影院| 国产精品国产馆在线真实露脸| 亚洲午夜激情网页| 老色鬼精品视频在线观看播放| 成人免费观看男女羞羞视频| 欧美日韩精品欧美日韩精品一综合| 日韩视频一区二区| 国产精品久久久久久久久免费丝袜 | 在线成人免费观看| 国产亚洲女人久久久久毛片|