Vigenère Cipher 维吉尼亚加解密算法

维吉尼亚的加解密有两种方法。


 


第一种是查表:第一行为明文,第一列为密钥,剩余的为对应的密文






 




--------------------------------------------------------------------------------


 


 


第二种方法是转化计算法:逐个将字符转化为从零开始的数字,对数字进行加密/解密后,再转化


为字符。


本文要用c++实现第二种方法,并且为了操作方便,使用了MFC框架(附工程下载)


核心代码如下:




//cipher.h  额外添加的文件,用来放置相关算法,此文件独立于MFC外,可直接移植到支持


CString的项目中
int* CStringToInt(CString str){
    //将CString转换为zero_based整数
    int size=str.GetLength();
    int *asc_space=new int[size];//使用new为了返回时不被消除
    for (int i=0;i<size;i++)
    {
        asc_space[i]=int(str.GetAt(i));
        if(asc_space[i]>64&&asc_space[i]<91)        //A-Z转化
            asc_space[i]-=65;
        else if(asc_space[i]>96&&asc_space[i]<123)    //a-z转化
            asc_space[i]-=97;
    }    
    return asc_space;
}


void Encode(CString key,CString plain,CString &cipher){
    //维吉尼亚加密算法
    int *keycode=CStringToInt(key);
    int *plaincode=CStringToInt(plain);
    int *ciphercode=CStringToInt(plain);
    int keysize=key.GetLength();
    int plainsize=plain.GetLength();
    int flag=0;
    CString blank(' ',plainsize+1);    //预留一个字节放\0
    cipher=blank;                    //生成空白的密文
    for (int i=0;i<plainsize;i++)
    {
        if(flag>=keysize)            //轮换钥匙
            flag=0;
        ciphercode[i]=(plaincode[i]+keycode[flag])%26;    //求密文的数字码
        cipher.SetAt(i,'A'+ciphercode[i]);                //生成密文
        ++flag;
    }
    cipher.SetAt(i,'\0');                //在末尾放入\0
    delete keycode,plaincode,ciphercode;//释放CStringToInt()申请的空间
}


void Decode(CString key,CString &plain,CString cipher){
    //加密稍作修改就是解密算法
    int *keycode=CStringToInt(key);
    int *plaincode=CStringToInt(cipher);
    int *ciphercode=CStringToInt(cipher);
    int keysize=key.GetLength();
    int ciphersize=cipher.GetLength();
    int flag=0;
    CString blank(' ',ciphersize+1);    
    plain=blank;                    
    for (int i=0;i<ciphersize;i++)
    {
        if(flag>=keysize)    
            flag=0;
        //+26是为了对密文数字码小于密钥数字码的情况进行矫正
        plaincode[i]=(ciphercode[i]-keycode[flag]+26)%26;    
        plain.SetAt(i,'a'+plaincode[i]);            
        ++flag;
    }
    plain.SetAt(i,'\0');
    delete keycode,plaincode,ciphercode;
}
 




//MFC OnButton()响应void CVigenereCipherDlg::OnEncrypt() //加密按钮
{
    UpdateData();
    if(m_key.IsEmpty()||m_plain.IsEmpty())
        MessageBox("密钥及明文不能为空!");
    else{
        Encode(m_key,m_plain,m_cipher);//调用加密函数
        UpdateData(false);
        m_ctrEDIT1.SetReadOnly(TRUE);//防止修改密钥
        m_ctrEDIT2.SetReadOnly(TRUE);//防止修改明文
        m_ctrEDIT3.SetReadOnly(TRUE);//防止修改密文
        m_ctrEDIT4.SetReadOnly(FALSE);
    }    
}


void CVigenereCipherDlg::OnDecrypt() //解密按钮
{
    UpdateData();
    if(m_key.IsEmpty()||m_cipher.IsEmpty())
        MessageBox("密钥及密文不能为空!");
    else{
        Decode(m_key,m_explainted,m_cipher);
        UpdateData(false);
        m_explainted="";
        m_ctrEDIT1.SetReadOnly(FALSE);
        m_ctrEDIT2.SetReadOnly(FALSE);
        m_ctrEDIT3.SetReadOnly(FALSE);
        m_ctrEDIT4.SetReadOnly(TRUE);
    }
}
 




--------------------------------------------------------------------------------


 


测试结果如下图:


 






 


工程下载链接:


 http://files.cnblogs.com/zoffy/VigenereCipher.zip


上一篇javaweb学习总结(三十一)——国际化(i18n) 下一篇Shell最多可以输入多少个参数? 主题


推荐 解密 算法 加密 框架 移植 猜你在找 Java:如何使用Cipher类对字符串进行加密解密算法基


础-加密与解密-程序设计ios AES128加密解密算法PHP实现RSA算法对数据加密解密JAVA实现RSA加


密解密 非对称算法Android DES加密解密算法微盾PHP脚本加密专家php解密算法java加密解密研究


4、UrlBase64算法学习php需要了解的点2 - PHP 一组加密解密算法RSA算法签名技术 C/ 


C++/JAVA/C#/DELPHI/VB加密解密结果一样
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值