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

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

?? des.cpp

?? des的加解密過程
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// Des.cpp: implementation of the CDes class.
//
//////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include "MixedCS.h"
#include "Des.h"
#include "Window.h"
#include "GfL.h"

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

///////////////////////////////////////////////////////////////////////////////
// DES Tables Define
///////////////////////////////////////////////////////////////////////////////

// initial permutation 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
};
// final permutation IP^-1 
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
};
// expansion operation matrix
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
};
// permuted choice table (key) 
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
};
// permuted choice key (table) 
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
};
// number left rotations of pc1 
const static char LOOP_Table[16] = 
{
	1,1,2,2,2,2,2,2,1,2,2,2,2,2,2,1
};
// The (in)famous S-boxes 
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
};

///////////////////////////////////////////////////////////////////////////////
// CDes Functions
///////////////////////////////////////////////////////////////////////////////
#define CHECK(x)			{if( !(x) ) return false;}
#define CHECK_MSG(x,msg)	{if( !(x) ){CWindow::ShowMessage(msg);return false;}}
#define FILE_CHECK(x,file)	{if( !(x) ) {RunError(file);return false;}}

/******************************************************************************/
//	名稱:Encrypt
//	功能:加密
//  參數:KeyStr為0結尾的密鑰串,長度<=16,可為任意字符
//	返回:加密成功返回true,否則返回false
//  備注:當密鑰長度>8時,系統自動使用3次DES加密
//	更新:2002/12/25
//	作者:0200980胡德華
/******************************************************************************/
bool CDes::Encrypt(const char *OutFile,const char *InFile,const char *KeyStr)
{
	CHECK( KeyStr && OpenFile(OutFile,InFile) )

	FILE_CHECK( Encrypt(fh_out,fh_in,KeyStr),OutFile )

	CloseFile();
	return true;
}
/******************************************************************************/
//	名稱:Decrypt
//	功能:解密
//  參數:KeyStr為0結尾的密鑰串,長度<=16,可為任意字符
//	返回:解密成功返回true,否則返回false
//  備注:當密鑰長度>8時,系統自動使用3次DES解密
//	更新:2002/12/25
//	作者:0200980胡德華
/******************************************************************************/
bool CDes::Decrypt(const char *OutFile,const char *InFile,const char *KeyStr)
{
	CHECK( KeyStr && OpenFile(OutFile,InFile) )

	FILE_CHECK( Decrypt(fh_out,fh_in,KeyStr),OutFile )

	CloseFile();
	return true;
}
/******************************************************************************/
//	名稱:Encrypt
//	功能:加密
//  參數:fh_out,fh_in為輸入輸出句柄;KeyStr為0結尾的密鑰串,長度<=16,可為任意字符
//	返回:加密成功返回true,否則返回false
//  備注:當密鑰長度>8時,系統自動使用3次DES加密
//	更新:2002/12/25
//	作者:0200935王俊川
/******************************************************************************/
bool CDes::Encrypt(HFILE &fh_out,HFILE &fh_in,const char *KeyStr)
{
	CWindow  wnd;
	long     len,k=0,TBlock;

    // 設置子密鑰
    CHECK( SetSubKey(KeyStr) )
	// 版本信息
	deshead.Ver = 1;
    // 文件長度信息
	deshead.TLen = GetFileSize((HANDLE)fh_in,0);
	// 計算總塊數
    TBlock=(deshead.TLen+BUFSIZE-1)/BUFSIZE;
	// 加密密鑰串(用于解密時驗證密鑰的正確性)
	memset(deskey,0,16);
	strcpy(deskey,KeyStr);
	Encrypt(deshead.DesKey,deskey,16);
	// 寫入信息頭
	_lwrite(fh_out,(char*)&deshead,sizeof(deshead));
    // 顯示等待光標
	wnd.ShowWaitCursor();

	// 讀取明文到緩沖區
	while( (len=_lread(fh_in,databuf,BUFSIZE)) >0 )
	{   // 顯示加密進度
        wnd.SetWindowCaption("共計%d塊數據,DES正在加密第%d塊......",TBlock,++k);
        // 將緩沖區長度變為8的倍數
		len = ((len+7)>>3)<<3;
		// 在緩沖區中加密
		Encrypt(databuf,databuf,len);
		// 將密文寫入輸出文件
		_lwrite(fh_out,databuf,len);
	}

    // 結束等待光標
	wnd.EndWaitCursor();
	return true;
}
/******************************************************************************/
//	名稱:Decrypt
//	功能:解密
//  參數:fh_out,fh_in為輸入輸出句柄;KeyStr為0結尾的密鑰串,長度<=16,可為任意字符
//	返回:解密成功返回true,否則返回false
//  備注:當密鑰長度>8時,系統自動使用3次DES解密
//	更新:2002/12/25
//	作者:0200935王俊川
/******************************************************************************/
bool CDes::Decrypt(HFILE &fh_out,HFILE &fh_in,const char *KeyStr)
{
	CWindow  wnd;
	long     len,k=0,TBlock;

    // 設置子密鑰
    CHECK( SetSubKey(KeyStr) )
	// 讀取信息頭并檢查長度
	CHECK_MSG( _lread(fh_in,&deshead,sizeof(deshead)) == sizeof(deshead),
	           "錯誤:該文件不是有效的DES加密文件!" )
    // 版本控制
	CHECK_MSG( deshead.Ver ==1,"該版程序無法解密此文件。\n請使用該程序的最新版。")
	// 解密密鑰串
    Decrypt(deshead.DesKey,deshead.DesKey,16);
	// 驗證密鑰的正確性
	memset(deskey,0,16);
	strcpy(deskey,KeyStr);//密鑰串長度一定<=16
    CHECK_MSG( !memcmp(deshead.DesKey,deskey,16), "錯誤:DES密鑰不正確! ");
	// 計算總塊數
	TBlock=(deshead.TLen+BUFSIZE-1)/BUFSIZE;
	// 顯示等待光標
	wnd.ShowWaitCursor();

	// 讀取密文到緩沖區
	while( (len=_lread(fh_in,databuf,BUFSIZE)) >0 )
	{   // 顯示解密進度
    	wnd.SetWindowCaption("共計%d塊數據,DES正在解密第%d塊......",TBlock,++k);
		// 將緩沖區長度變為8的倍數
		len = ((len+7)>>3)<<3;
		// 在緩沖區中解密
		Decrypt(databuf,databuf,len);
		// 將明文寫入輸出文件

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品日韩欧美一区二区| 日韩视频123| 日韩一区二区视频| 中文字幕第一区| 日韩精品免费专区| 99久久免费视频.com| 日韩亚洲欧美在线观看| 亚洲视频一区二区在线| 久久国产尿小便嘘嘘尿| 欧洲视频一区二区| 日韩一区在线看| 精品一区二区在线看| 欧美群妇大交群的观看方式| 国产精品伦一区二区三级视频| 美国十次综合导航| 在线播放日韩导航| 香蕉av福利精品导航 | 国产精品乱码一区二区三区软件 | 欧美本精品男人aⅴ天堂| 一区二区三区四区蜜桃| 成人久久久精品乱码一区二区三区 | 制服丝袜av成人在线看| 亚洲人成影院在线观看| 成人黄色国产精品网站大全在线免费观看| 717成人午夜免费福利电影| 一卡二卡三卡日韩欧美| 日本道色综合久久| 亚洲一区免费视频| 欧洲一区二区三区免费视频| 亚洲欧美日韩在线| 色婷婷综合久色| 亚洲欧美日韩综合aⅴ视频| 99riav久久精品riav| 日韩理论在线观看| 色哟哟精品一区| 亚洲欧美国产77777| 色诱视频网站一区| 亚洲国产wwwccc36天堂| 欧美日韩国产首页| 日本伊人精品一区二区三区观看方式| 欧美日韩国产色站一区二区三区| 亚洲一区二区美女| 欧美片网站yy| 日韩精品久久理论片| 日韩欧美中文字幕一区| 精品视频1区2区3区| 亚洲主播在线观看| 欧美日韩国产综合一区二区三区 | 中文字幕一区不卡| 91在线视频免费观看| 日韩一区中文字幕| 色偷偷久久一区二区三区| 亚洲国产精品一区二区久久恐怖片| 日本大香伊一区二区三区| 视频一区国产视频| 久久久五月婷婷| 精东粉嫩av免费一区二区三区| 国产人成一区二区三区影院| 国产精品一色哟哟哟| 欧美激情一区二区三区全黄| 色综合天天综合狠狠| 亚洲一区二区三区国产| 欧美岛国在线观看| 国产成人av资源| 亚洲一二三专区| 精品国产免费一区二区三区四区| 成人午夜视频福利| 日韩精品一卡二卡三卡四卡无卡| 久久午夜电影网| 欧洲精品一区二区三区在线观看| 美女mm1313爽爽久久久蜜臀| 国产精品高潮久久久久无| 欧美人牲a欧美精品| 国产一区欧美二区| 亚洲第一福利一区| 中文字幕欧美国产| 欧美一区二区三区在线观看视频| 成人高清视频免费观看| 日韩成人伦理电影在线观看| 国产精品第五页| 精品久久久久av影院| 色婷婷av一区二区| 国产精品一区二区免费不卡| 丝袜美腿高跟呻吟高潮一区| 国产精品视频观看| 欧美xxxxx牲另类人与| 欧美在线不卡视频| www.一区二区| 韩国毛片一区二区三区| 粉嫩aⅴ一区二区三区四区五区| 亚洲成人免费视| 亚洲精选免费视频| 中文字幕精品—区二区四季| 精品蜜桃在线看| 欧美精品在欧美一区二区少妇| 99久久精品免费| 国产高清在线精品| 九九久久精品视频 | 国产精品私房写真福利视频| 色综合天天综合网国产成人综合天 | 在线观看91视频| 成人午夜av在线| 国产一区二区美女诱惑| 久久99精品一区二区三区三区| 亚洲一区在线观看免费观看电影高清| 国产精品卡一卡二卡三| 中文字幕精品综合| 国产精品天干天干在线综合| 日本一区二区三区在线观看| 久久尤物电影视频在线观看| 欧美成人精品高清在线播放| 欧美一级高清片| 欧美二区三区的天堂| 欧美日韩日日摸| 欧美日本不卡视频| 欧美精品在线视频| 日韩一区二区精品葵司在线| 337p亚洲精品色噜噜| 欧美一区二区三区性视频| 69久久99精品久久久久婷婷 | 亚洲自拍偷拍麻豆| 一区二区三区影院| 性做久久久久久免费观看| 天天色综合天天| 看电视剧不卡顿的网站| 国产麻豆成人精品| 欧美天堂一区二区三区| 欧美蜜桃一区二区三区| 日韩一区二区免费高清| 欧美videos中文字幕| 国产日韩欧美麻豆| 国产精品久久久久四虎| 亚洲精品乱码久久久久| 日韩在线一二三区| 国产在线一区观看| 成人高清视频免费观看| 欧美午夜电影网| 欧美一区二区在线不卡| 久久久久亚洲蜜桃| 亚洲猫色日本管| 蜜桃精品视频在线| 成人综合在线观看| 在线精品视频一区二区三四 | 久久综合狠狠综合| 国产精品久久久久婷婷| 图片区小说区区亚洲影院| 久久精品国产亚洲a| 91亚洲国产成人精品一区二区三| 在线一区二区三区| 久久综合色婷婷| 又紧又大又爽精品一区二区| 午夜欧美视频在线观看| 国产精品中文字幕一区二区三区| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 欧美videossexotv100| 国产午夜精品久久久久久久| 日韩理论片网站| 免费观看久久久4p| 99精品久久99久久久久| 日韩欧美在线综合网| 亚洲色图一区二区| 久久精品国产精品亚洲精品| 99久久99久久综合| 欧美成人精品高清在线播放| 亚洲精品va在线观看| 国产成人精品一区二区三区四区 | 亚洲午夜私人影院| 国产成人aaaa| 91麻豆精品国产无毒不卡在线观看 | 91.成人天堂一区| 国产精品久久久久久亚洲伦| 麻豆成人久久精品二区三区红| 色综合久久综合中文综合网| 国产亚洲精品福利| 三级久久三级久久| 色伊人久久综合中文字幕| 国产欧美一区二区精品久导航 | 成人黄色小视频| 欧美一级二级三级乱码| 亚洲一区影音先锋| 色综合天天天天做夜夜夜夜做| 久久久久久久久久电影| 日本不卡视频一二三区| 欧美日韩五月天| 一区二区三区在线免费| www.日韩精品| 国产免费久久精品| 国产传媒久久文化传媒| 久久久久一区二区三区四区| 久热成人在线视频| 日韩一区二区精品在线观看| 亚洲v精品v日韩v欧美v专区| 欧美午夜一区二区三区| 夜夜嗨av一区二区三区网页| 成人一道本在线| 亚洲国产精品精华液2区45| 国产精品77777竹菊影视小说| 精品少妇一区二区三区在线视频| 免费成人你懂的| 欧美一区二区三区在|