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

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

?? desdlg.cpp

?? DES加密算法的實現和演示
?? 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], //經過初始置換后的明文二進制
		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一区二区三区免费野_久草精品视频
欧美视频在线一区二区三区| 日韩欧美综合一区| 欧美嫩在线观看| 国产欧美日韩综合精品一区二区| 日韩三级伦理片妻子的秘密按摩| 日韩理论片中文av| 久久99在线观看| 欧美揉bbbbb揉bbbbb| 欧美经典一区二区| 美女一区二区在线观看| 欧美日韩一区高清| 亚洲日本在线看| 国产精品一级二级三级| 精品奇米国产一区二区三区| 亚洲最新视频在线观看| 不卡视频免费播放| 久久精品视频在线看| 麻豆成人免费电影| 91精品国产aⅴ一区二区| 亚洲激情欧美激情| 91首页免费视频| 中文字幕在线观看一区| 粉嫩高潮美女一区二区三区| 免费看欧美女人艹b| 高潮精品一区videoshd| 精品日韩99亚洲| 蜜桃一区二区三区在线观看| 精品1区2区3区| 亚洲v日本v欧美v久久精品| 色菇凉天天综合网| 亚洲精品国产成人久久av盗摄| www.爱久久.com| 国产精品乱码人人做人人爱| 成人在线视频首页| 亚洲欧洲色图综合| 91麻豆精品在线观看| 亚洲乱码精品一二三四区日韩在线 | 国产精选一区二区三区| 精品久久久久久久久久久院品网| 久久国产综合精品| 2023国产一二三区日本精品2022| 国模无码大尺度一区二区三区| 日韩欧美国产小视频| 精品一区二区av| 中文在线一区二区| 日本韩国欧美三级| 日韩激情一区二区| 国产亚洲欧洲997久久综合| 粉嫩aⅴ一区二区三区四区| 中文字幕人成不卡一区| 在线区一区二视频| 欧美aaaaa成人免费观看视频| 精品国内二区三区| 成人性生交大片免费看中文 | 免费日韩伦理电影| 久久午夜老司机| 91香蕉视频污在线| 日韩和欧美一区二区三区| 26uuu久久天堂性欧美| 成人福利视频在线看| 亚洲图片欧美视频| 精品国产91乱码一区二区三区 | av男人天堂一区| 性欧美大战久久久久久久久| 久久综合狠狠综合久久综合88| 丰满少妇久久久久久久| 五月天视频一区| 亚洲国产成人一区二区三区| 欧美亚男人的天堂| 国产一区二区三区观看| 亚洲一区二区三区四区在线免费观看| 91精品国产麻豆| 99久久婷婷国产| 久久精品99久久久| 亚洲精品高清在线观看| 久久久久久久久久久久电影| 欧美视频一区二区三区在线观看| 国产一区视频在线看| 亚洲制服丝袜一区| 国产欧美中文在线| 91精品国产全国免费观看 | 成人永久免费视频| 日韩av电影天堂| 美女尤物国产一区| 欧美极品xxx| 欧美精品v国产精品v日韩精品| 国产成人超碰人人澡人人澡| 亚洲高清在线精品| 国产精品久久久久久久午夜片 | 久久 天天综合| 亚洲女人****多毛耸耸8| 久久综合国产精品| 欧美一区二区美女| 欧美日韩精品一区二区在线播放 | 欧美精品三级在线观看| 91丨porny丨蝌蚪视频| 国产精品一级二级三级| 麻豆国产91在线播放| 日韩不卡免费视频| 亚洲妇女屁股眼交7| 亚洲精品国产品国语在线app| 久久综合五月天婷婷伊人| 男男gaygay亚洲| 成人综合婷婷国产精品久久| 亚洲综合成人在线| 国产精品伦理在线| 国产亚洲1区2区3区| 91精品免费在线| 欧美精品自拍偷拍| 欧美日韩久久久久久| 欧美日韩精品是欧美日韩精品| 91美女在线看| 一本到一区二区三区| 99久久久国产精品免费蜜臀| 成人激情校园春色| 9人人澡人人爽人人精品| 成人性生交大片免费| 粉嫩av一区二区三区| 国产91富婆露脸刺激对白| 国产v日产∨综合v精品视频| 国产精品538一区二区在线| 国产精品一区二区在线看| 国产精品一区二区三区乱码| 高清成人在线观看| 99re成人在线| 欧美在线啊v一区| 9191成人精品久久| 欧美成人a在线| 国产色综合久久| 日韩理论在线观看| 亚洲福利一区二区| 青草av.久久免费一区| 激情综合色播五月| 国产精品18久久久久久久久久久久 | av在线播放不卡| 在线亚洲一区观看| 91精品国产麻豆| 久久精品视频一区二区三区| 国产精品国模大尺度视频| 亚洲久草在线视频| 亚洲成人精品在线观看| 久久影音资源网| 欧美日韩国产乱码电影| 欧美性感一类影片在线播放| 欧美日韩一区二区三区视频| 日韩免费福利电影在线观看| 久久久国产精品麻豆| 亚洲欧美日韩国产另类专区| 亚洲va欧美va人人爽| 国产精品综合在线视频| 91老司机福利 在线| 欧美一区二区三区性视频| 久久精品视频在线免费观看| 亚洲综合色区另类av| 狠狠狠色丁香婷婷综合激情| 一本一道久久a久久精品综合蜜臀| 欧美日韩中文一区| 久久精品一区蜜桃臀影院| 一二三四社区欧美黄| 精品亚洲成a人| 欧美色涩在线第一页| 欧美大胆一级视频| 欧美久久免费观看| 久久婷婷国产综合精品青草| 综合在线观看色| 蜜桃一区二区三区在线观看| 成人av小说网| 欧美一区二区三区四区高清| 亚洲欧洲av一区二区三区久久| 秋霞午夜鲁丝一区二区老狼| 色欧美日韩亚洲| 国产欧美一区二区三区鸳鸯浴 | 成人免费毛片嘿嘿连载视频| 欧美精品在线视频| 亚洲欧美日韩系列| 国产精品99久久久久久久女警 | 久久精品男人天堂av| 性做久久久久久| 91国偷自产一区二区使用方法| 亚洲精品在线电影| 懂色av一区二区三区免费观看| 九九精品一区二区| 色综合色综合色综合色综合色综合| 欧美电影一区二区三区| 1024成人网| 国产精品自拍网站| 日韩一区二区三区高清免费看看| 亚洲精品国久久99热| 99久久综合色| 日本一二三不卡| 成人一道本在线| 亚洲国产成人在线| 成人免费毛片app| 亚洲精品在线免费观看视频| 免费成人你懂的| 欧美高清www午色夜在线视频| 亚洲一区二三区| 欧美日韩久久不卡| 三级影片在线观看欧美日韩一区二区 | 色视频一区二区|