?? rsadlg.cpp
字號:
// RsaDlg.cpp : implementation file
//
#include "stdafx.h"
#include "ASYMMETRIC KEY CRYPTOSYSTEM.h"
#include "RsaDlg.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CRsaDlg dialog
CRsaDlg::CRsaDlg(CWnd* pParent /*=NULL*/)
: CDialog(CRsaDlg::IDD, pParent)
{
//{{AFX_DATA_INIT(CRsaDlg)
m_IN = _T("");
m_OUT = _T("");
m_E = _T("");
m_D = _T("");
m_N = _T("");
m_Len = -1;
//}}AFX_DATA_INIT
CTime t = CTime::GetCurrentTime();
seed=t.GetSecond();
srand(seed);
}
void CRsaDlg::DoDataExchange(CDataExchange* pDX)
{
CDialog::DoDataExchange(pDX);
//{{AFX_DATA_MAP(CRsaDlg)
DDX_Text(pDX, IDC_INPUT, m_IN);
DDX_Text(pDX, IDC_OUTPUT, m_OUT);
DDX_Text(pDX, IDC_E, m_E);
DDX_Text(pDX, IDC_D, m_D);
DDX_Text(pDX, IDC_N, m_N);
DDX_CBIndex(pDX, IDC_COMBO, m_Len);
//}}AFX_DATA_MAP
}
BEGIN_MESSAGE_MAP(CRsaDlg, CDialog)
//{{AFX_MSG_MAP(CRsaDlg)
ON_BN_CLICKED(IDC_ENCRYPT, OnClickEncrypt)
ON_BN_CLICKED(IDC_DECRYPT, OnClickDecrypt)
ON_BN_CLICKED(IDC_BUTTON_GET, OnButtonGet)
ON_BN_CLICKED(IDC_BUTTON_PUT, OnButtonPut)
ON_BN_CLICKED(IDC_introduceRsa, OnintroduceRsa)
ON_BN_CLICKED(IDC_Rashelp, OnRashelp)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CRsaDlg message handlers
void CRsaDlg::OnClickEncrypt()
{
// TODO: Add your control notification handler code here
if(ready==0)
{
m_OUT=_T("請先輸入或生成N、D、E");
UpdateData(FALSE);
return;
}
UpdateData(TRUE);
if(m_IN.GetLength()>256)
{
m_OUT=_T("N不得大于256位");
UpdateData(FALSE);
return;
}
for(int i=0;i<m_IN.GetLength();i++)
{
if((m_IN[i]<'0')||
((m_IN[i]>'9')&&(m_IN[i]<'A'))||
((m_IN[i]>'F')&&(m_IN[i]<'a'))||
(m_IN[i]>'f'))
{
m_OUT=_T("待加密數據必須為0-9或A-F或a-f組成的整數");
UpdateData(FALSE);
return;
}
}
P.Get(m_IN);
if(P.Cmp(N)>=0)
{
m_OUT=_T("待加密數據必須小于N");
UpdateData(FALSE);
return;
}
Q.Mov(P.RsaTrans(E,N));
Q.Put(m_OUT);
UpdateData(FALSE);
}
void CRsaDlg::OnClickDecrypt()
{
// TODO: Add your control notification handler code here
if((ready==0)||(Q.m_ulValue[0]==0))
{
m_OUT=_T("請先進行加密");
UpdateData(FALSE);
return;
}
Q.Get(m_OUT);
P.Mov(Q.RsaTrans(D,N));
P.Put(m_OUT);
UpdateData(FALSE);
}
void CRsaDlg::OnButtonGet()
{
// TODO: Add your control notification handler code here
ready=1;
UpdateData(TRUE);
int len=2;
for(int i=0;i<m_Len;i++){len*=2;}
CTime t0=CTime::GetCurrentTime();
P.Mov(0);
Q.Mov(0);
N.Mov(0);
E.Mov(0);
P.GetPrime(len);
Q.GetPrime(len);
N.Mov(P.Mul(Q));
N.Put(m_N);
P.m_ulValue[0]--;
Q.m_ulValue[0]--;
P.Mov(P.Mul(Q));
D.Mov(0x10001);
m_D="10001";
E.Mov(D.Euc(P));
E.Put(m_E);
CTime t1=CTime::GetCurrentTime();
CTimeSpan t=t1-t0;
m_OUT.Format("%d",t.GetTotalSeconds());
m_OUT+=" 秒";
Q.m_ulValue[0]=0;
UpdateData(FALSE);
}
void CRsaDlg::OnButtonPut()
{
// TODO: Add your control notification handler code here
UpdateData(TRUE);
ready=0;
if(m_N.GetLength()>256)
{
m_OUT=_T("N不得大于256位");
UpdateData(FALSE);
return;
}
if(m_E.GetLength()>256)
{
m_OUT=_T("E不得大于256位");
UpdateData(FALSE);
return;
}
if(m_D.GetLength()>10)
{
m_OUT=_T("N不得大于10位");
UpdateData(FALSE);
return;
}
for(int i=0;i<m_N.GetLength();i++)
{
if((m_N[i]<'0')||
((m_N[i]>'9')&&(m_N[i]<'A'))||
((m_N[i]>'F')&&(m_N[i]<'a'))||
(m_N[i]>'f'))
{
m_OUT=_T("N必須為0-9或A-F或a-f組成的整數");
UpdateData(FALSE);
return;
}
}
for(i=0;i<m_E.GetLength();i++)
{
if((m_E[i]<'0')||
((m_E[i]>'9')&&(m_E[i]<'A'))||
((m_E[i]>'F')&&(m_E[i]<'a'))||
(m_E[i]>'f'))
{
m_OUT=_T("E必須為0-9或A-F或a-f組成的整數");
UpdateData(FALSE);
return;
}
}
for(i=0;i<m_D.GetLength();i++)
{
if((m_D[i]<'0')||
((m_D[i]>'9')&&(m_D[i]<'A'))||
((m_D[i]>'F')&&(m_D[i]<'a'))||
(m_D[i]>'f'))
{
m_OUT=_T("D必須為0-9或A-F或a-f組成的整數");
UpdateData(FALSE);
return;
}
}
N.Get(m_N);
D.Get(m_D);
E.Get(m_E);
if((N.Cmp(E)<=0)||(N.Cmp(D)<=0))
{
m_OUT=_T("N必須大于D、E");
UpdateData(FALSE);
return;
}
ready=1;
Q.m_ulValue[0]=0;
}
void CRsaDlg::OnintroduceRsa()
{
// TODO: Add your control notification handler code here
m_OUT=_T(" RSA算法是第一個能同時用于加密和數字簽名的算法,也易于理解和操作。RSA是被研究得最廣泛的公鑰算法,從提出到現在已近二十年,經歷了各種攻擊的考驗,逐漸為人們接受,普遍認為是目前最優秀的公鑰方案之一。RSA的安全性依賴于大數的因子分解,但并沒有從理論上證明破譯RSA的難度與大數分解難度等價。即RSA的重大缺陷是無法從理論上把握它的保密性能如何,而且密碼學界多數人士傾向于因子分解不是NPC問題。RSA的缺點主要有:A)產生密鑰很麻煩,受到素數產生技術的限制,因而難以做到一次一密。B)分組長度太大,為保證安全性,n 至少也要 600 bits以上,使運算代價很高,尤其是速度較慢,較對稱密碼算法慢幾個數量級;且隨著大數分解技術的發展,這個長度還在增加,不利于數據格式的標準化。目前,SET(Secure Electronic Transaction)協議中要求CA采用2048比特長的密鑰,其他實體使用1024比特的密鑰。這種算法1978年就出現了,它是第一個既能用于數據加密也能用于數字簽名的算法。它易于理解和操作,也很流行。算法的名字以發明者的名字命名:Ron Rivest, AdiShamir 和Leonard Adleman。但RSA的安全性一直未能得到理論上的證明。RSA的安全性依賴于大數分解。公鑰和私鑰都是兩個大素數( 大于 100個十進制位)的函數。據猜測,從一個密鑰和密文推斷出明文的難度等同于分解兩個大素數的積。");
UpdateData(FALSE);
return;
}
void CRsaDlg::OnRashelp()
{
// TODO: Add your control notification handler code here
m_OUT=_T(" 你可以先點擊“手動輸入N,D,E”然后在N、E和D框分別輸入N、E和D的值,然后在“加密內容”框輸入要加密的內容,再點擊“加密”按鈕即可進行加密。把加密后的數據復制進“加密內容”框,點擊“解密”按鈕即可進行解密。你也可以在“密鑰長度”下拉選框中選定密鑰的長度,點擊“隨機選擇N、E”按鈕隨機生成N、E,然后輸入數據進行加密和解密,步驟與前面一樣的。");
UpdateData(FALSE);
return;
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -