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

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

?? ideadlg.cpp

?? 這是一個用VC編的IDEA加解密算法的演示系統(tǒng)
?? CPP
字號:
// IDEADlg.cpp : implementation file
//

#include "stdafx.h"
#include "IDEA.h"
#include "IDEADlg.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()

/////////////////////////////////////////////////////////////////////////////
// CIDEADlg dialog

CIDEADlg::CIDEADlg(CWnd* pParent /*=NULL*/)
	: CDialog(CIDEADlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CIDEADlg)
	m_str = _T("");
	m_encrypt = -1;
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CIDEADlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CIDEADlg)
	DDX_Control(pDX, IDC_EDIT1, m_code);
	DDX_Control(pDX, IDCANCEL, m_cancel);
	DDX_Control(pDX, IDOK, m_ok);
	DDX_Control(pDX, IDC_EDIT2, m_key);
	DDX_Text(pDX, IDC_EDIT4, m_str);
	DDX_Radio(pDX, IDC_RADIO1, m_encrypt);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CIDEADlg, CDialog)
	//{{AFX_MSG_MAP(CIDEADlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON1, OnButton1)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CIDEADlg message handlers

BOOL CIDEADlg::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
	m_encrypt=0;
	UpdateData(FALSE);
	return TRUE;  // return TRUE  unless you set the focus to a control
}

void CIDEADlg::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 CIDEADlg::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 CIDEADlg::OnQueryDragIcon()
{
	return (HCURSOR) m_hIcon;
}


void CIDEADlg::OnOK() 
{
	// TODO: Add extra validation here
	UpdateData(TRUE);
    
	char array[17],karray[33];
	int i,j,r,s;
	unsigned short int a,b,c,d,temp;
	unsigned short int X[4],K[8],Key[52],Y[4];

    for(i=0;i<17;i++)
		array[i]='\0';
	m_code.GetWindowText(array,17);
	i=0;
	while(array[i]!='\0')
		i++;
	if(i<16){
		MessageBox("請輸入64比特的十六進(jìn)制明文!"); 
		return;
	}
	for(i=0;i<16;){//將十六進(jìn)制的字符變成數(shù)字
		for(j=0;j<4;j++){
            if(array[i]>='0'&&array[i]<='9'){
               temp=array[i]-48;
			}else
				if(array[i]>='A'&&array[i]<='F'){
                   temp=array[i]-55;
				}else
					if(array[i]>='a'&&array[i]<='f'){
						temp=array[i]-87;
					}
					else{
						MessageBox("請輸入十六進(jìn)制明文!"); 
						return;
					}
            switch(i%4){
			case 0:
				a=0x000f&a;
                a=temp<<12;
                break;
            case 1:
	            b=0x000f&b;
                b=temp<<8;
                break;
            case 2:
	            c=0x000f&c;
                c=temp<<4;
                break;
            case 3:
	            d=0x000f&d;
                d=temp;
                break;
			}
			i++;
		}
        X[i/4-1]=a|b|c|d;
	}
	for(i=0;i<33;i++)
		karray[i]='\0';
	m_key.GetWindowText(karray,33);
	i=0;
	while(karray[i]!='\0')
		i++;
	if(i<32){
		MessageBox("請輸入128比特的十六進(jìn)制密鑰!"); 
		return;
	}
	for(i=0;i<32;){
		for(j=0;j<4;j++){
			if(karray[i]>='0'&&karray[i]<='9'){
               temp=karray[i]-48;
			}else
				if(karray[i]>='A'&&karray[i]<='F'){
					temp=karray[i]-55;
				}else
					if(karray[i]>='a'&&karray[i]<='f'){
						temp=karray[i]-87;
					}
					else{ 
						MessageBox("請輸入十六進(jìn)制密鑰!"); 
						return;
					}
			switch(i%4){
			case 0:
				a=temp<<12;
                break;
            case 1:
                b=temp<<8;
                break;
            case 2:
                c=temp<<4;
                break;
            case 3:
                d=temp;
                break;
			}
            i++;
		}
        K[i/4-1]=a|b|c|d;
	}
	generate(K,Key);//擴(kuò)展種子
	if(m_encrypt==0) TRACE("encrypt");
	else{//解密時把加密密鑰轉(zhuǎn)換成解密密鑰
		unsigned short int t1,t2,t3,t4;
		unsigned short int Keytemp[52];

		for(i=0;i<52;i++)
			Keytemp[i]=Key[i];
		r=0;
		s=51;
        t1=mulInv(Key[r]);
		r++;
		t2=-Key[r];
		r++;
		t3=-Key[r];
		r++;
		t4=mulInv(Key[r]);
		r++;
		Keytemp[s]=t4;
	    s--;
		Keytemp[s]=t3;
		s--;
		Keytemp[s]=t2;
		s--;
		Keytemp[s]=t1;
		s--;
        for(i=0;i<7;i++){
			t1=Key[r];
			r++;
			t2=Key[r];
			r++;
			Keytemp[s]=t2;
			s--;
			Keytemp[s]=t1;
			s--;

            t1=mulInv(Key[r]);
    		r++;
			t2=-Key[r];
			r++;
			t3=-Key[r];
			r++;
			t4=mulInv(Key[r]);
			r++;
			Keytemp[s]=t4;
			s--;
			Keytemp[s]=t2;
			s--;
			Keytemp[s]=t3;
			s--;
			Keytemp[s]=t1;
			s--;
		}
		t1=Key[r];
		r++;
		t2=Key[r];
		r++;
		Keytemp[s]=t2;
		s--;
		Keytemp[s]=t1;
		s--;
		t1=mulInv(Key[r]);
		r++;
		t2=-Key[r];
		r++;
		t3=-Key[r];
		r++;
		t4=mulInv(Key[r]);
		r++;
		Keytemp[s]=t4;
		s--;
		Keytemp[s]=t3;
		s--;
		Keytemp[s]=t2;
		s--;
		Keytemp[s]=t1;
		s--;
		
		for(i=0;i<52;i++)
			Key[i]=Keytemp[i];
	}
	turn(X,Key,Y);//加密或解密
    m_str="";

	DectoHex(Y,m_str);//將十進(jìn)制數(shù)轉(zhuǎn)換成十六進(jìn)制數(shù)

	UpdateData(FALSE);
}
//模65537乘法
unsigned short int CIDEADlg::mul(unsigned short int a,unsigned short int b)
{
	unsigned int c,d,e;
    c=a;
    d=b;
    e=c*d;
    if(e){
       d=0xffff&e;
       c=e>>16;
       return (d-c)+(d<c);
	}else if(a){
         return 1-a;
	}else{
         return 1-b;
	}
}
//擴(kuò)展密鑰
void CIDEADlg::generate(unsigned short int *k, unsigned short int *key)
{
	unsigned short int ktemp[8];
    unsigned short int temp,a,b;
	int i,j;
	
	for(i=0;i<8;i++){
		key[i]=k[i];
	}
    for(j=8;j<52;){//左移16位
		temp=k[0];
		for(i=0;i<8;i++){
			k[i]=k[i+1];
		}
		k[7]=temp;

		for(i=0;i<7;i++){//左移9位
			a=0x007f&k[i];
			a=a<<9;
			b=0xff80&k[i+1];
			b=b>>7;
			ktemp[i]=a|b;
		}
        a=0x007ff&k[7];
        a=a<<9;
        b=0xff80&k[0];
        b=b>>7;
        ktemp[7]=a|b;
		
		for(i=0;i<8;i++){
			k[i]=ktemp[i];
		}
		
		for(i=0;i<8;i++,j++){
			key[j]=k[i];
		}
	}
	return;
}

void CIDEADlg::OnCancel() 
{
	CDialog::OnCancel();
}

//輪函數(shù)
void CIDEADlg::turn(unsigned short *X, unsigned short *Key, unsigned short *Y)
{
	unsigned short int e0,e1,e2,e3;
	unsigned short int f0,f1;
	unsigned short int g,h,u,v;
	unsigned short int Z[8][6];
	int i,j,r;
	
	for(i=0,r=0;i<8;i++){
		for(j=0;j<6;j++){
			Z[i][j]=Key[r];
			r++;
		}
	}
	
	for(i=0;i<8;i++){
		e0=mul(X[0],Z[i][0]);
	    e1=X[1]+Z[i][1];
        e2=X[2]+Z[i][2];
	    e3=mul(X[3],Z[i][3]);
		
		f0=e0^e2;
		f1=e1^e3;
		
		g=mul(f0,Z[i][4]);
		h=g+f1;
		u=mul(h,Z[i][5]);
		v=g+u;
	
		Y[0]=e0^u;
		Y[1]=e2^u;
		Y[2]=e1^v;
		Y[3]=e3^v;
		
		X[0]=Y[0];
		X[1]=Y[1];
	    X[2]=Y[2];
	    X[3]=Y[3];
	}
	Y[0]=mul(X[0],Key[r]);
	r++;
    Y[1]=X[2]+Key[r];
    r++;
    Y[2]=X[1]+Key[r];
    r++;
    Y[3]=mul(X[3],Key[r]);
	return;
}
//十進(jìn)制轉(zhuǎn)換成十六進(jìn)制
void CIDEADlg::DectoHex(unsigned short *Y, CString outstr)
{
	unsigned short int m=0,n,base;
	CString ch;
	int i,j;
	m_str="";
	for(i=0;i<4;i++){
		outstr="";
	base=Y[i];
	for(j=0;j<4;j++){
		m=base/16;
		n=base%16;
		if(n<=9)
			ch=n+48;
		else 
		    ch=n+55;
        outstr=ch+outstr;
	    base=m;
	}
	m_str=m_str+outstr;
	}
}
//模65537乘法的逆的計算
unsigned short int CIDEADlg::mulInv(unsigned short int x)
{
    unsigned short int t0,t1;
	unsigned short int q,y;

	if(x<=1)
		return x;
	t1=0x10001/x;
	y=0x10001%x;
	if(y==1)
		return 1-t1;
	t0=1;
	do{
		q=x/y;
		x=x%y;
		t0+=q*t1;
		if(x==1)
			return t0;
		q=y/x;
		y=y%x;
		t1+=q*t0;
	}while(y!=1);
	return 1-t1;
}
void CIDEADlg::OnButton1() 
{
	// TODO: Add your control notification handler code here
	CAboutDlg dlg;
	dlg.DoModal();
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品免费观看| 亚洲视频一区在线观看| 亚洲成人av福利| 欧美日韩亚洲综合在线| 亚洲成人综合视频| 5566中文字幕一区二区电影 | 91国偷自产一区二区开放时间 | 亚洲视频一二三| 色婷婷亚洲综合| 亚洲国产你懂的| 日韩一区二区在线看| 精品一区二区三区在线观看国产| 国产亚洲精品bt天堂精选| 99精品一区二区| 亚洲高清三级视频| 欧美tickling挠脚心丨vk| 高清国产午夜精品久久久久久| 中文字幕一区二区在线观看| 欧美综合久久久| 精品一区二区免费| 中文字幕制服丝袜成人av| 欧美色视频在线| 国产一区二区在线影院| 亚洲人成在线观看一区二区| 欧美精品乱人伦久久久久久| 国产老妇另类xxxxx| 亚洲精品成人少妇| 精品国产一区二区三区不卡| 91蜜桃婷婷狠狠久久综合9色| 偷拍一区二区三区| 中文子幕无线码一区tr| 欧美日韩国产另类不卡| 国产在线国偷精品产拍免费yy| 亚洲丝袜另类动漫二区| 日韩免费视频一区| 色中色一区二区| 极品美女销魂一区二区三区免费| 最新欧美精品一区二区三区| 欧美一级在线免费| 99九九99九九九视频精品| 六月丁香婷婷色狠狠久久| 亚洲色欲色欲www| 精品第一国产综合精品aⅴ| 欧美四级电影网| 国产suv精品一区二区三区| 午夜视黄欧洲亚洲| 最新国产精品久久精品| 精品国产成人系列| 欧美人与z0zoxxxx视频| 本田岬高潮一区二区三区| 美腿丝袜亚洲三区| 亚洲国产一区二区三区| 亚洲天堂网中文字| 欧美激情一区二区三区全黄 | 欧美tk—视频vk| 欧美日韩一区二区三区四区五区 | 亚洲欧美综合色| 久久嫩草精品久久久精品| 欧美猛男男办公室激情| 色综合久久中文综合久久牛| 岛国一区二区三区| 精品影院一区二区久久久| 日韩中文字幕区一区有砖一区| 亚洲色图在线看| 亚洲欧美影音先锋| 中文字幕免费观看一区| 国产视频视频一区| 久久影视一区二区| www一区二区| 日韩三级中文字幕| 日韩精品一区二区三区视频| 在线电影院国产精品| 欧美日韩久久一区| 欧美亚洲综合色| 欧美午夜片在线观看| 91麻豆精品视频| 91免费在线播放| 91极品视觉盛宴| 欧美日韩精品专区| 在线成人免费观看| 欧美一区二区在线视频| 欧美一区二区三区免费视频| 制服丝袜av成人在线看| 日韩三级av在线播放| 日韩久久久久久| www国产精品av| 中文字幕精品在线不卡| 亚洲色图色小说| 亚洲一区视频在线| 日韩国产在线一| 精品一区二区三区香蕉蜜桃| 国产乱色国产精品免费视频| 成人av资源网站| 91成人在线免费观看| 欧洲国内综合视频| 日韩欧美你懂的| 国产三级精品三级在线专区| 亚洲欧美色一区| 亚洲小少妇裸体bbw| 麻豆成人久久精品二区三区红| 国产在线精品免费av| 99久久99久久久精品齐齐| 欧美无砖砖区免费| 日韩精品在线网站| 国产精品盗摄一区二区三区| 亚洲午夜久久久久久久久电影院| 男男成人高潮片免费网站| 国产在线观看一区二区| 91在线无精精品入口| 91超碰这里只有精品国产| 国产日产欧产精品推荐色| 亚洲天堂中文字幕| 蜜桃在线一区二区三区| 成人免费视频免费观看| 精品视频一区三区九区| 日韩你懂的在线播放| 亚洲丝袜另类动漫二区| 麻豆视频观看网址久久| 一本色道久久加勒比精品| 日韩欧美一二三四区| 伦理电影国产精品| 成人动漫精品一区二区| 欧美一级电影网站| 成人欧美一区二区三区视频网页| 婷婷亚洲久悠悠色悠在线播放| 国产精品99久久久| 欧美美女bb生活片| 1000精品久久久久久久久| 日韩国产成人精品| 色悠悠久久综合| 久久亚洲综合色| 日韩国产欧美三级| 91婷婷韩国欧美一区二区| 精品国产成人在线影院 | 一区二区三区免费在线观看| 狠狠狠色丁香婷婷综合久久五月| 色综合色狠狠综合色| 久久精品免视看| 日韩精品久久久久久| 91福利资源站| 国产精品久久久久aaaa樱花| 精品在线免费观看| 欧美日本一区二区在线观看| 日韩一区有码在线| 国产精品亚洲专一区二区三区| 欧美一区午夜精品| 午夜精品福利久久久| 色天天综合久久久久综合片| 国产精品午夜电影| 国产美女娇喘av呻吟久久| 日韩欧美激情在线| 视频精品一区二区| 欧美日韩精品久久久| 亚洲主播在线观看| 色噜噜狠狠色综合中国| 国产精品不卡一区二区三区| 懂色av中文字幕一区二区三区| 欧美成人精品1314www| 青青草原综合久久大伊人精品 | 欧美一级免费大片| 亚洲444eee在线观看| 精品视频在线视频| 亚洲成人先锋电影| 欧美日韩日日骚| 性做久久久久久| 欧美日韩国产免费一区二区| 亚洲第一综合色| 欧美精品亚洲一区二区在线播放| 亚洲成人你懂的| 欧美无乱码久久久免费午夜一区| 亚洲综合一二三区| 精品视频一区三区九区| 日韩激情一区二区| 日韩三级免费观看| 国产乱色国产精品免费视频| 国产色婷婷亚洲99精品小说| 成人性视频免费网站| 综合自拍亚洲综合图不卡区| 一本一道久久a久久精品综合蜜臀| 伊人色综合久久天天人手人婷| 欧美性色aⅴ视频一区日韩精品| 亚洲综合精品自拍| 91精品国产综合久久蜜臀| 老司机精品视频一区二区三区| 精品久久久久香蕉网| 国产成人综合网| 亚洲美女区一区| 欧美精品久久一区| 国产一区福利在线| 日韩美女精品在线| 欧美福利视频一区| 国产又黄又大久久| 亚洲色图都市小说| 欧美一区二区三区在| 国产做a爰片久久毛片| 亚洲人成伊人成综合网小说| 欧美色图免费看| 国产伦精品一区二区三区视频青涩| 中文一区一区三区高中清不卡| 色呦呦国产精品|