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

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

?? desdlg.cpp

?? DES加密算法的實現(xiàn)和演示
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// DESDlg.cpp : implementation file
//

#include "stdafx.h"
#include "DES.h"
#include "DESDlg.h"
#include<math.h>
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CAboutDlg dialog used for App About

class CAboutDlg : public CDialog
{
public:
	CAboutDlg();

// Dialog Data
	//{{AFX_DATA(CAboutDlg)
	enum { IDD = IDD_ABOUTBOX };
	//}}AFX_DATA

	// ClassWizard generated virtual function overrides
	//{{AFX_VIRTUAL(CAboutDlg)
	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
	//}}AFX_VIRTUAL

// Implementation
protected:
	//{{AFX_MSG(CAboutDlg)
	//}}AFX_MSG
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialog(CAboutDlg::IDD)
{
	//{{AFX_DATA_INIT(CAboutDlg)
	//}}AFX_DATA_INIT
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CAboutDlg)
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialog)
	//{{AFX_MSG_MAP(CAboutDlg)
		// No message handlers
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDESDlg dialog

CDESDlg::CDESDlg(CWnd* pParent /*=NULL*/)
	: CDialog(CDESDlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CDESDlg)
	key = _T("12345678");
	m_runable=false;
	m = _T("");
	s = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CDESDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CDESDlg)
	DDX_Text(pDX, IDC_key, key);
	DDX_Text(pDX, IDC_m, m);
	DDX_Text(pDX, IDC_s, s);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CDESDlg, CDialog)
	//{{AFX_MSG_MAP(CDESDlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_go, Ongo)
	ON_BN_CLICKED(IDC_back, Onback)
	ON_BN_CLICKED(clear1, Onclear1)
	ON_BN_CLICKED(clear2, Onclear2)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDESDlg message handlers

BOOL CDESDlg::OnInitDialog()
{
	CDialog::OnInitDialog();

	// Add "About..." menu item to system menu.

	// IDM_ABOUTBOX must be in the system command range.
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		CString strAboutMenu;
		strAboutMenu.LoadString(IDS_ABOUTBOX);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// Set the icon for this dialog.  The framework does this automatically
	//  when the application's main window is not a dialog
	SetIcon(m_hIcon, TRUE);			// Set big icon
	SetIcon(m_hIcon, FALSE);		// Set small icon
	
	// TODO: Add extra initialization here
	
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CDESDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialog::OnSysCommand(nID, lParam);
	}
}

// If you add a minimize button to your dialog, you will need the code below
//  to draw the icon.  For MFC applications using the document/view model,
//  this is automatically done for you by the framework.

void CDESDlg::OnPaint() 
{
	if (IsIconic())
	{
		CPaintDC dc(this); // device context for painting

		SendMessage(WM_ICONERASEBKGND, (WPARAM) dc.GetSafeHdc(), 0);

		// Center icon in client rectangle
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// Draw the icon
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialog::OnPaint();
	}
}

// The system calls this to obtain the cursor to display while the user drags
//  the minimized window.
HCURSOR CDESDlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}

void CDESDlg::Ongo() 
{
	// TODO: Add your control notification handler code here
	KEY_BIO();
	if(m_runable)
	{
		DES_ENCIPHER();
	}
}

void CDESDlg::KEY_BIO()
{
	UpdateData(TRUE);
	if(key.GetLength()!=8)
	{
		MessageBox("密鑰必須為八位","密鑰錯!",MB_ICONSTOP|MB_OK);
		m_runable=false;
	}
	else
	{
		m_runable=true;
		char ch;
		static int i,j,str[8];

		for(i=0;i<8;i++)
		{
			ch=key.GetAt(i);
			for(j=0;j<8;j++)
			{
				 str[j]=ch%2;
				 ch=ch/2;
			} 
			for(j=7;j>=0;j--)
				Key[i*8+j]=str[j];
		}
	}
}

void CDESDlg::DES_ENCIPHER()
{
	int m[65],  //用來存放二進制的明文
		m1[65], //經(jīng)過初始置換后的明文二進制
		i,C0[29],D0[29],k0[57];
    //IP初始置換表
    int ip[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};	
	//IP逆置換表
	int IP_REVERSE[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};
	//P56置換表
	int P56[57]={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};

	SOURCE_BIO();
/************************************************************/
//生成子密鑰
	for(i=1;i<57;i++)
	  k0[i]=Key[P56[i-1]];
    for(i=1;i<29;i++)
	  C0[i]=k0[i];
	for(i=29;i<=56;i++)
	  D0[i-28]=k0[i];

	int CE[29],DE[29],Cx[29],Dx[29];
	for(i=1;i<=28;i++){
		CE[i]=C0[i];
		DE[i]=D0[i];
	}
	for(int num=1;num<=16;num++){
		DES_GenerateSubkey(CE,DE,Cx,Dx,K,num);
		for(i=1;i<=28;i++){
			CE[i]=Cx[i];
			DE[i]=Dx[i];
		}
	}
//生成完畢
/************************************************************/
	/**********/
	/*加密過程*/
	/**********/
	s="";          //設置字符串變量為空
	long len=m_StrSource.GetLength();
    long count=0;

	while((m_fSize--)>0){//while
		for(i=1;i<=64;i++){
			m[i]=(m_StrSource.GetAt(count)-'0');
			count++;
		}
		for(i=1;i<=64;i++)
			m1[i]=m[ip[i-1]];

		for(i=1;i<=32;i++)
			L0[i]=m1[i];     //明文左側的初始化
		for(i=33;i<=64;i++)
			R0[i-32]=m1[i];  //明文右側的初始化
		/**************************************************/
		//進行十六次迭代
		int RE[33],LE[33],Lx[33],Rx[33];
		for(i=1;i<=32;i++){
			RE[i]=R0[i];
			LE[i]=L0[i];
		}
		for(num=1;num<=16;num++){
			DES_ITERATIVE(LE,RE,Lx,Rx,K[num]);
			for(i=1;i<=32;i++){
				LE[i]=Lx[i];
				RE[i]=Rx[i];
			}
		}
	    //迭代完畢
		/************************************************************/
		int t[65]; 
		for(i=1;i<=32;i++)
		{
			t[i]=LE[i];
			t[i+32]=RE[i];
		}
		for(i=1;i<=64;i++)   //將密文進行IP逆置換
			t1[i]=t[IP_REVERSE[i-1]];

		for(i=1;i<=64;i++)
		{
			s=s+(char)(48+t1[i]);   //48為字符0的ASCII碼
			if(i%8==0)                //逢8位空格
				s=s+"   ";
		}

	}//while
	UpdateData(false);
	MessageBox("加密已完成!","提示",MB_OK|MB_ICONINFORMATION);
}

void CDESDlg::SOURCE_BIO()
{
	char ch;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆免费看| 美女mm1313爽爽久久久蜜臀| 亚洲高清免费视频| 国产精品一区二区三区网站| 91色porny在线视频| 亚洲精品在线网站| 天天色综合成人网| zzijzzij亚洲日本少妇熟睡| 欧美一级搡bbbb搡bbbb| 亚洲综合丝袜美腿| kk眼镜猥琐国模调教系列一区二区| 欧美女孩性生活视频| 国产精品护士白丝一区av| 久久激情五月激情| 在线不卡一区二区| 一区二区三区四区蜜桃| 国产成人精品免费一区二区| 日韩一级成人av| 日本亚洲欧美天堂免费| 在线一区二区三区四区五区 | 亚洲电影在线免费观看| 91免费国产在线| 国产精品蜜臀av| 国产电影精品久久禁18| 久久久国际精品| 久久国产综合精品| 欧美肥胖老妇做爰| 日韩av二区在线播放| 欧美一区二区三区电影| 美国毛片一区二区| 欧美一区二区三区的| 日韩avvvv在线播放| 欧美一区二区三区视频免费| 蜜桃视频一区二区三区 | 欧美成人国产一区二区| 日韩1区2区3区| 欧美一区二区日韩| 美女网站色91| 精品99一区二区三区| 日本午夜精品视频在线观看| 亚洲精品欧美激情| 欧美人与性动xxxx| 久久久精品影视| 国产精品影音先锋| 成人小视频在线观看| 欧美极品aⅴ影院| 国产91丝袜在线播放| 国产日韩欧美一区二区三区乱码| 国产精品99久久久久久久vr| 亚洲国产成人午夜在线一区 | 欧美男女性生活在线直播观看| 夜夜嗨av一区二区三区网页| 欧美视频精品在线| 久久国产免费看| 国产亚洲婷婷免费| 一本久久综合亚洲鲁鲁五月天| 亚洲国产视频网站| 欧美电影免费观看高清完整版| 精品一区二区综合| 国产精品电影一区二区三区| 欧美三级中文字幕| 国产尤物一区二区| 亚洲美女一区二区三区| 91精品久久久久久蜜臀| 国产69精品久久久久777| 亚洲欧美日韩国产中文在线| 正在播放一区二区| 国产69精品一区二区亚洲孕妇| 一区二区三区影院| 久久只精品国产| 色哟哟一区二区在线观看| 天天操天天综合网| 久久九九全国免费| 在线电影欧美成精品| 成人激情综合网站| 免费观看在线综合色| 国产精品久久久久影院亚瑟| 在线电影欧美成精品| 91美女在线视频| 国模一区二区三区白浆| 亚洲愉拍自拍另类高清精品| 久久久亚洲精品石原莉奈| 在线观看av一区| 成人av先锋影音| 奇米在线7777在线精品| 亚洲自拍欧美精品| 国产精品无遮挡| 2024国产精品| 欧美精品乱码久久久久久 | 欧美精品久久久久久久多人混战| 国产成人在线影院| 日本午夜一区二区| 亚洲成a人片在线观看中文| 中文字幕一区二区三区视频| 久久久精品黄色| 日韩视频免费观看高清完整版在线观看 | 亚洲一区二区五区| 亚洲特级片在线| 国产精品嫩草99a| 日韩免费一区二区| 欧美一区二区国产| 欧美午夜理伦三级在线观看| 成人黄色国产精品网站大全在线免费观看| 91一区二区在线| 亚洲欧美日韩成人高清在线一区| 欧美刺激午夜性久久久久久久| 色呦呦一区二区三区| 91在线精品一区二区| 1024成人网| 久久精品一区二区三区av| 日韩一区二区三免费高清| 在线视频一区二区三区| 色综合久久综合网97色综合| 福利一区二区在线| 国产不卡视频在线观看| 成人动漫在线一区| www.欧美日韩国产在线| 99精品视频在线观看免费| 成人美女视频在线观看| 成人国产一区二区三区精品| youjizz国产精品| 色综合天天综合狠狠| 91亚洲精品久久久蜜桃网站| 91看片淫黄大片一级在线观看| 91一区二区在线| 欧美性色黄大片| 制服丝袜中文字幕亚洲| 欧美一级日韩一级| 国产亚洲欧美激情| 亚洲一区在线播放| 亚洲午夜国产一区99re久久| 婷婷综合另类小说色区| 免费在线成人网| 国产成人在线视频免费播放| www.欧美色图| 欧美精三区欧美精三区| 欧美成人bangbros| 国产精品女同一区二区三区| 亚洲免费观看高清完整版在线| 一级做a爱片久久| 乱中年女人伦av一区二区| 国产丶欧美丶日本不卡视频| 91麻豆国产在线观看| 欧美一区二区在线不卡| 久久综合色婷婷| 亚洲色图清纯唯美| 日韩电影在线观看电影| 成人免费视频视频| 欧美三级一区二区| 久久品道一品道久久精品| 亚洲欧美另类在线| 麻豆一区二区三| 成人动漫中文字幕| 日韩三级.com| 成人欧美一区二区三区黑人麻豆| 夜夜嗨av一区二区三区网页| 国内精品写真在线观看| 在线精品视频一区二区三四| 精品国产一区二区精华| 亚洲精品久久久久久国产精华液| 日韩中文字幕麻豆| www.99精品| 久久久综合精品| 亚洲成a人片综合在线| 成人一道本在线| 欧美一区二区福利在线| 一区免费观看视频| 久久99精品国产麻豆不卡| 欧美这里有精品| 中文字幕精品一区二区三区精品| 五月综合激情网| www.亚洲人| 欧美精品一区二区三| 亚洲动漫第一页| 91官网在线免费观看| 国产精品免费久久久久| 精品亚洲成av人在线观看| 欧美久久一二三四区| 一区二区日韩av| av中文字幕不卡| 国产人成一区二区三区影院| 性做久久久久久久久| 99精品一区二区三区| 国产日产精品一区| 激情五月婷婷综合| 91精品国产综合久久国产大片| 亚洲精品国产视频| eeuss国产一区二区三区| 久久综合色婷婷| 精品一区二区三区在线播放视频| 91激情在线视频| 亚洲欧美激情插| 91免费国产在线| 国产精品福利一区| 高清不卡一区二区在线| 久久久精品综合| 国产美女久久久久| 国产日韩三级在线| 国产一区二区三区免费播放| 欧美videossexotv100|