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

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

?? cdma f9dlg.cpp

?? 第三代移動系統(tǒng)中以Kasumi為內(nèi)核的另一加密算法-f8算法的VC++實現(xiàn)
?? CPP
字號:
// CDMA f9Dlg.cpp : implementation file


#include "stdafx.h"
#include "CDMA f9.h"
#include "CDMA f9Dlg.h"

#include <iostream.h>
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <stdlib.h>
#include <time.h>
#include <math.h>

extern void Kasumi(char*,const char*);
extern int hextoint(char x);
extern char inttohex(int x);

#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()

/////////////////////////////////////////////////////////////////////////////
// CCDMAf9Dlg dialog

CCDMAf9Dlg::CCDMAf9Dlg(CWnd* pParent /*=NULL*/)
	: CDialog(CCDMAf9Dlg::IDD, pParent)
{
	//{{AFX_DATA_INIT(CCDMAf9Dlg)
	m_plain_text = _T("");
	m_count_i = _T("");
	m_fresh = _T("");
	m_message = _T("");
	m_direction = _T("");
	m_hex_f9_indata = _T("");
	m_ik = _T("");
	m_mac_i = _T("");
	//}}AFX_DATA_INIT
	// Note that LoadIcon does not require a subsequent DestroyIcon in Win32
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CCDMAf9Dlg::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CCDMAf9Dlg)
	DDX_Text(pDX, IDC_PLAIN_TEXT, m_plain_text);
	DDX_Text(pDX, IDC_COUNT_I, m_count_i);
	DDV_MaxChars(pDX, m_count_i, 32);
	DDX_Text(pDX, IDC_FRESH, m_fresh);
	DDV_MaxChars(pDX, m_fresh, 32);
	DDX_Text(pDX, IDC_MESSAGE, m_message);
	DDX_Text(pDX, IDC_DIRECTION, m_direction);
	DDV_MaxChars(pDX, m_direction, 1);
	DDX_Text(pDX, IDC_HEX_f9_INDATA, m_hex_f9_indata);
	DDX_Text(pDX, IDC_IK, m_ik);
	DDV_MaxChars(pDX, m_ik, 32);
	DDX_Text(pDX, IDC_MAC_I, m_mac_i);
	//}}AFX_DATA_MAP
}

BEGIN_MESSAGE_MAP(CCDMAf9Dlg, CDialog)
	//{{AFX_MSG_MAP(CCDMAf9Dlg)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_EN_CHANGE(IDC_PLAIN_TEXT, OnChangePlainText)
	ON_EN_CHANGE(IDC_COUNT_I, OnChangeCountI)
	ON_EN_CHANGE(IDC_FRESH, OnChangeFresh)
	ON_EN_CHANGE(IDC_DIRECTION, OnChangeDirection)
	ON_EN_CHANGE(IDC_IK, OnChangeIk)
	ON_BN_CLICKED(IDC_CLEAR, OnClear)
	ON_BN_CLICKED(IDC_AUTOINPUT, OnAutoinput)
	ON_BN_CLICKED(IDC_CLACULATE_MAC_I, OnClaculateMacI)
	ON_BN_CLICKED(IDC_SAVE, OnSave)
	ON_BN_CLICKED(IDC_EXIT, OnExit)
	ON_BN_CLICKED(IDC_F9HELP, OnF9help)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CCDMAf9Dlg message handlers

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


// 明文的輸入
void CCDMAf9Dlg::OnChangePlainText() 
{
	UpdateData(TRUE);

	m_hex_f9_indata="";
	m_mac_i="";
	
	int i;
	for(i=0;i<m_plain_text.GetLength();i++)
		if(!isxdigit(m_plain_text[i]))
			m_plain_text.Delete(i);
	m_message=m_plain_text;

	UpdateData(FALSE);		
}


// 參數(shù)COUNT-I的輸入
void CCDMAf9Dlg::OnChangeCountI() 
{
	UpdateData(TRUE);

	m_hex_f9_indata="";
	m_mac_i="";

	int i;
	for(i=0;i<m_count_i.GetLength();i++)
		if(m_count_i[i]!='0' && m_count_i[i]!='1')
			m_count_i.Delete(i);
	UpdateData(FALSE);	
}


// 參數(shù)FRESH的輸入
void CCDMAf9Dlg::OnChangeFresh() 
{
	UpdateData(TRUE);

	m_hex_f9_indata="";
	m_mac_i="";
	
	int i;
	for(i=0;i<m_fresh.GetLength();i++)
		if(m_fresh[i]!='0' && m_fresh[i]!='1')
			m_fresh.Delete(i);
	
	UpdateData(FALSE);	
}


// 參數(shù)DIRECTION的輸入
void CCDMAf9Dlg::OnChangeDirection() 
{
	UpdateData(TRUE);
	
	m_hex_f9_indata="";
	m_mac_i="";
	
	int i;
	for(i=0;i<m_direction.GetLength();i++)
		if(m_direction[i]!='0' && m_direction[i]!='1')
			m_direction.Delete(i);
	
	UpdateData(FALSE);	
}


// 參數(shù)IK的輸入 
void CCDMAf9Dlg::OnChangeIk() 
{
	UpdateData(TRUE);
	
	m_mac_i="";
	
	int i;
	for(i=0;i<m_ik.GetLength();i++)
		if(!isxdigit(m_ik[i]))
			m_ik.Delete(i);
	
	UpdateData(FALSE);		
}


// 清零按鈕
void CCDMAf9Dlg::OnClear() 
{
	m_plain_text="";
	m_count_i="";
	m_fresh="";
	m_message="";
	m_direction="";
	m_hex_f9_indata="";
	m_ik="";
	m_mac_i="";
	
	UpdateData(FALSE);	
}


// 自動輸入按鈕,設置明文為64bit
void CCDMAf9Dlg::OnAutoinput() 
{
	int i;
	int j=0;
	char temp[49];
	char f9in[64];

	srand((unsigned)time(NULL));
	for(i=0;i<1;i++)
	{
		temp[i]=inttohex(rand()%2);
	}
	temp[i]='\0';
	m_direction=temp;

	for(i=0;i<16;i++)
		temp[i]=inttohex(rand()%16);
	temp[i]='\0';
	m_plain_text=temp;
	
	for(i=0;i<32;i++,j++)
	{
		temp[i]=inttohex(rand()%2);
		f9in[j]=temp[i];
	}
	temp[i]='\0';
	m_count_i=temp;

	for(i=0;i<32;i++,j++)
	{
		temp[i]=inttohex(rand()%2);
		f9in[j]=temp[i];
	}
	temp[i]='\0';
	m_fresh=temp;

	m_message=m_plain_text;

	int sum[16]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};

	// count-i 和 fresh
	for(i=0;i<64;i++)
		sum[i/4] += (hextoint(f9in[i])<<(3-i%4));
	for(i=0;i<16;i++)
		temp[i]=inttohex(sum[i]);

	// message 直接給temp
	for(i=16;i<32;i++)
		temp[i]=m_message[i-16];
	if(m_direction[0]=='0')
		temp[i]='4';
	else temp[i]='C';

	for(i=33;i<48;i++)
		temp[i]='0';
	temp[i]='\0';
	m_hex_f9_indata=temp;

	for(i=0;i<32;i++)
		temp[i]=inttohex(rand()%16);
	temp[i]='\0';
	m_ik=temp;
	
	m_mac_i="";
	
	UpdateData(FALSE);
	
}


// 計算MAC-I
void CCDMAf9Dlg::OnClaculateMacI() 
{
	UpdateData(TRUE);

	// 就各種參數(shù)的錯誤輸入進行報錯
	if(m_plain_text.GetLength()==0)
	{	
		MessageBox("請輸入明文!", "參數(shù)輸入錯誤", MB_OK | MB_ICONERROR);
		return ;
	}

	if(m_count_i.GetLength()!=32)
	{	
		MessageBox("請檢查參數(shù) COUNT-I 的輸入!", "參數(shù)輸入錯誤", MB_OK | MB_ICONERROR);
		return ;
	}
	
	if(m_fresh.GetLength()!=32)
	{	
		MessageBox("請檢查參數(shù) FRESH 的輸入!", "參數(shù)輸入錯誤", MB_OK | MB_ICONERROR);
		return ;
	}
	
	if(m_direction.GetLength()!=1)
	{	
		MessageBox("請檢查參數(shù) DIRECTION 的輸入!", "參數(shù)輸入錯誤", MB_OK | MB_ICONERROR);
		return ;
	}
	
	if(m_ik.GetLength()!=32)
	{	
		MessageBox("請檢查參數(shù) IK 的輸入!", "參數(shù)輸入錯誤", MB_OK | MB_ICONERROR);
		return ;
	}

	m_message=m_plain_text;

	// 計算f9的實時輸入

	char *f9in;
	if( (64+m_plain_text.GetLength()*4+2)%64==0)
		f9in = new char[64+m_plain_text.GetLength()*4+2];
	else f9in = new char[((64+m_plain_text.GetLength()*4+2)/64+1)*64];

	int i,j;
	j=0;

	for(i=0;i<32;i++,j++)
		f9in[j]=m_count_i[i];
	
	for(i=0;i<32;i++,j++)
		f9in[j]=m_fresh[i];
	
	f9in[64+m_message.GetLength()*4]=m_direction[0];
	f9in[64+m_message.GetLength()*4+1]='1';

	// 非64bit的整數(shù)倍,加若干個0使其成為64bit的整數(shù)倍
	if( (64+m_plain_text.GetLength()+2)%64!=0)
		for(i=64+m_message.GetLength()*4+2;i<(((64+m_plain_text.GetLength()*4+2)/64+1)*64);i++)
			f9in[i]='0';

	// 把各個參數(shù)整合
	char *temp;
	temp = new char[((64+m_plain_text.GetLength()*4+2)/64+1)*64/4];
	int sum[16]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
	for(i=0;i<64;i++)
		sum[i/4] += (hextoint(f9in[i])<<(3-i%4));
	for(i=0;i<16;i++)
		temp[i]=inttohex(sum[i]);
	for(i=0;i<m_message.GetLength();i++)
		temp[i+16]=m_message[i];

	if((64+m_plain_text.GetLength()*4+2)%64!=0)
	{
		if(m_direction[0]=='0')
			temp[16+m_message.GetLength()]='4';
		else temp[16+m_message.GetLength()]='C';
		for(i=16+m_message.GetLength()+1;i<((64+m_plain_text.GetLength()*4+2)/64+1)*64/4;i++)
		temp[i]='0';
	}
	temp[i]='\0';

	// 16進制顯示
	m_hex_f9_indata=temp;

	char km_128bit[]="ABCDEF01234567890123456789ABCDEF";
	char A[]="0000000000000000";
	char B[]="0000000000000000";
	int blocks;
	blocks = int(ceil((double)m_hex_f9_indata.GetLength()/16));

	for (j=0;j<blocks;j++)
	{
		for (i=0;i<16;i++)
			A[i]=inttohex(hextoint(m_hex_f9_indata[i+j*16])^hextoint(A[i]));

		Kasumi(A,m_ik);

		for (i=0;i<16;i++)
			B[i]=inttohex(hextoint(B[i])^hextoint(A[i]));
	}

	for (i=0;i<32;i++)
		temp[i]=inttohex(hextoint(m_ik[i])^hextoint(km_128bit[i]));

	Kasumi(B,temp);

	B[8]='\0';

	m_mac_i=B;

	UpdateData(FALSE);

}


// 保存按鈕
void CCDMAf9Dlg::OnSave() 
{
	CFileDialog dlg(FALSE, ".txt", "", OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT, "text file(*.txt)|*.txt||", this);

	if (dlg.DoModal() != IDOK)
		return;

	CStdioFile file;

	if (!file.Open(dlg.GetPathName(), CFile::modeWrite | CFile::modeCreate))
	{
		MessageBox("open failed!");
		return;
	}

	file.WriteString("★★★ 3G 完整性算法 f9 ( Kasumi ) ★★★\n\n");
	file.WriteString("明文:\n");
	file.WriteString(m_plain_text+"\n\n");
	file.WriteString("f9函數(shù)的輸入數(shù)據(jù):\n");
	file.WriteString(m_hex_f9_indata+"\n\n");
	file.WriteString("IK:\n");
	file.WriteString(m_ik+"\n\n");
	file.WriteString("數(shù)據(jù)完整性的消息認證碼:\n");
	file.WriteString(m_mac_i+"\n\n");

	file.Close();
}


// 退出按鈕
void CCDMAf9Dlg::OnExit() 
{
	OnCancel();	
}


// 幫助按鈕
void CCDMAf9Dlg::OnF9help() 
{
	::ShellExecute(m_hWnd, "open", "f9help.chm", NULL, NULL, SW_SHOWDEFAULT);	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91福利在线看| 337p亚洲精品色噜噜| 欧美图片一区二区三区| 日韩精品一区二区三区中文精品| 久久精品国产一区二区三 | aaa亚洲精品| 在线播放中文字幕一区| 亚洲日本一区二区三区| 国产一区二区日韩精品| 欧美日韩精品福利| 国产精品欧美久久久久无广告 | 国产精品亚洲一区二区三区在线 | 精品国产乱码久久久久久1区2区| 自拍偷拍欧美精品| 国产精品一二三在| 精品日本一线二线三线不卡| 亚洲国产综合视频在线观看| 91亚洲国产成人精品一区二三| 久久综合中文字幕| 老司机午夜精品99久久| 欧美电影影音先锋| 亚洲五码中文字幕| 欧美三级电影精品| 亚洲午夜精品网| 欧日韩精品视频| 亚洲精品成人在线| 一本久久a久久精品亚洲| 成人免费小视频| 97se亚洲国产综合自在线不卡 | 91丨porny丨首页| 欧美激情中文不卡| 成人网页在线观看| 欧美激情在线看| 成+人+亚洲+综合天堂| 国产精品热久久久久夜色精品三区| 国产馆精品极品| 久久精品男人的天堂| 粉嫩在线一区二区三区视频| 国产精品区一区二区三区| www.av亚洲| 亚洲一区二区视频在线观看| 欧美日韩一区不卡| 日韩av午夜在线观看| 精品国产sm最大网站| 狠狠色丁香久久婷婷综| 国产欧美一区二区精品性| 国产精品88888| 国产日韩欧美综合一区| av在线不卡电影| 夜夜嗨av一区二区三区四季av | 国产色一区二区| 成人黄色a**站在线观看| 亚洲三级在线播放| 欧美日韩精品欧美日韩精品一综合| 亚洲成人资源网| 日韩三级电影网址| 国产91富婆露脸刺激对白| 日韩一区欧美一区| 欧美丰满少妇xxxbbb| 国产伦精一区二区三区| 国产精品午夜在线观看| 欧美性猛交xxxx黑人交| 精品一区二区在线视频| 中文字幕一区二区视频| 欧美日韩精品一区视频| 国产精品亚洲成人| 一区二区理论电影在线观看| 日韩免费观看2025年上映的电影| 成人av网在线| 蜜桃久久久久久| 亚洲三级在线播放| 久久久久久久久久久久久久久99 | 国产一区二区三区美女| 中文字幕中文字幕在线一区| 欧美日韩国产首页| 成人深夜福利app| 日韩av一级电影| 亚洲欧美国产77777| 精品美女被调教视频大全网站| 91色乱码一区二区三区| 精品一区二区三区香蕉蜜桃| 亚洲精品成人悠悠色影视| 久久麻豆一区二区| 91精选在线观看| 色综合天天性综合| 国内精品伊人久久久久av影院| 亚洲乱码中文字幕综合| 国产欧美一区二区三区沐欲| 日韩一区二区在线免费观看| 成人高清av在线| 国产一区视频导航| 日韩精品电影一区亚洲| 亚洲精品写真福利| 国产精品毛片高清在线完整版| 欧美成人vr18sexvr| 欧美日韩另类国产亚洲欧美一级| 色综合天天做天天爱| 成人深夜视频在线观看| 国产福利不卡视频| 国产一区二区免费看| 美女一区二区三区在线观看| 亚洲午夜久久久久久久久电影院 | 日本韩国精品在线| 成人app在线| 成人综合在线视频| 国产成人精品www牛牛影视| 狠狠色狠狠色综合系列| 免费av成人在线| 免费不卡在线视频| 老汉av免费一区二区三区| 蜜桃久久久久久| 麻豆精品视频在线观看免费| 日韩国产欧美视频| 日本麻豆一区二区三区视频| 亚洲va韩国va欧美va精品| 一区二区三区 在线观看视频| 亚洲男人天堂av| 亚洲与欧洲av电影| 亚洲一区在线观看免费| 亚洲高清视频的网址| 日韩av在线免费观看不卡| 日韩高清中文字幕一区| 麻豆精品精品国产自在97香蕉| 日韩1区2区日韩1区2区| 另类欧美日韩国产在线| 国产原创一区二区三区| 国产99精品视频| 99久久99精品久久久久久| 91色九色蝌蚪| 欧美精品18+| 久久久亚洲高清| 中文字幕的久久| 亚洲综合色区另类av| 日韩和欧美一区二区三区| 另类调教123区| 成人福利视频网站| 欧美专区亚洲专区| 欧美tk丨vk视频| 国产精品婷婷午夜在线观看| 亚洲一区二区四区蜜桃| 久久99国产精品免费网站| 丁香另类激情小说| 欧美日韩成人一区| 久久免费午夜影院| 亚洲精品视频免费看| 蜜桃视频免费观看一区| 丁香网亚洲国际| 欧美日韩亚洲高清一区二区| 26uuu国产在线精品一区二区| 国产精品久久久久久久久免费相片| 一区二区三区视频在线观看| 首页亚洲欧美制服丝腿| 国产高清精品在线| 欧美性生交片4| 中文字幕欧美三区| 亚瑟在线精品视频| 成人精品视频.| 欧美一区二区三区在线视频| 日本一区二区三区高清不卡| 日本中文一区二区三区| 成人免费毛片aaaaa**| 欧美日韩成人激情| 亚洲天堂网中文字| 国产尤物一区二区| 欧美久久久久久久久中文字幕| 久久久五月婷婷| 亚洲成人高清在线| 日韩三级在线观看| 激情欧美日韩一区二区| 一区二区三区四区国产精品| 日本成人在线网站| 91污在线观看| 久久久综合九色合综国产精品| 亚洲精品国产一区二区三区四区在线| 久久97超碰色| 91精品国产91久久综合桃花| 日本一区二区电影| 韩国毛片一区二区三区| 在线不卡中文字幕| 亚洲黄色片在线观看| 成人视屏免费看| 欧美在线影院一区二区| 久久九九久精品国产免费直播| 国内成人免费视频| 国产精品卡一卡二| 在线一区二区观看| 亚洲福利国产精品| 欧美成人一区二区三区片免费| 国产真实精品久久二三区| 国产人久久人人人人爽| av日韩在线网站| 日韩精品欧美精品| 国产亚洲欧洲一区高清在线观看| 精品毛片乱码1区2区3区| jizzjizzjizz欧美| 亚洲成人免费影院| 国产清纯在线一区二区www| 91丨九色丨蝌蚪富婆spa| 丝袜亚洲精品中文字幕一区| 久久久不卡影院|