1

我正在尝试制作一个非常简单的凯撒密码算法来加密和解密游戏中的玩家数据,但我得到了一些奇怪的结果。算法的任务很简单,只需向前或向后推动 ascii 表中的字符。

std::string Encrypt(std::string in,int key)
{
    const char* chars=in.data();
    char* newchar=(char*)malloc(sizeof(char)*in.length());
    for(int c=0;c<in.length();c++)
    {
        newchar[c]=char(((int)chars[c])+key);//I suspect somewhere here is the problem
    }

    std::string out(newchar);
    return out;
}

LOGI("encrypt:%s",Encrypt("hello",10).data());
LOGI("decrypt:%s",Encrypt(Encrypt("hello",10),-10).data());

输出:

encrypt:rovvyu@ 
decrypt:hellok

我对加密知之甚少,我对 ascii 和整个字符在 c 中的工作方式知之甚少

4

3 回答 3

4
std::string Encrypt(const std::string & in, int key)
{
    std::string out(in);
    for(int i=0; i < in.length(); ++i)
    {
        out[i] += key;
    }
    return out;
}
于 2012-10-06T16:54:37.780 回答
0

问题在于将“key”添加到 a..z 中的值可能不会回到该范围内。就像是

if (chars[c] >= 'a' && chars[c] <='z') newchar[c] = 'a' + ((chars[c]-'a'+key)%26);
else if (chars[c] >= 'A' && chars[c] <='Z') newchar[c] = 'A' + ((chars[c]-'A'+key)%26);
else newchar[c] = chars[c];

希望您有充分的理由使用如此弱的东西。顺便说一句,使用 26 键反转。

于 2012-10-06T16:56:16.267 回答
-1

如果您只想知道如何制作凯撒密码,那很酷。如果您确实想保护某些数据,请不要这样做!它不再是一种加密方法,而不是猪拉丁语。

相反,请使用预先编写的加密库。不要自己写,因为它需要很长时间才能正确完成。AES 在大多数情况下都足够快且足够好,并且具有几乎适用于所有编程语言的库。

于 2012-11-16T00:08:09.723 回答