首页
社区
课程
招聘
请教一个vc写的22行加密函数
发表于: 2004-6-5 08:39 1658

请教一个vc写的22行加密函数

2004-6-5 08:39
1658
#define C1 52845
#define C2 22719

CString CCrypt::Encrypt(CString S, WORD Key) // 加密函数
{
        CString Result,str;
        int i,j;

        Result=S; // 初始化结果字符串
        for(i=0; i<S.GetLength(); i++) // 依次对字符串中各字符进行操作
        {
                Result.SetAt(i, S.GetAt(i)^(Key>>8)); // 将密钥移位后与字符异或
                Key = ((BYTE)Result.GetAt(i)+Key)*C1+C2; // 产生下一个密钥
        }
        S=Result; // 保存结果
        Result.Empty(); // 清除结果
        for(i=0; i<S.GetLength(); i++) // 对加密结果进行转换
        {
                j=(BYTE)S.GetAt(i); // 提取字符
                // 将字符转换为两个字母保存
                str="12"; // 设置str长度为2
                str.SetAt(0, 65+j/26);
                str.SetAt(1, 65+j%26);
                Result += str;
        }
        return Result;
虽然有注释,但是我想不出被加密的字符是如何转换的。
当如下调用时,请给我写出具体的计算转换步骤,或者请注释更具体一些
strPasswd=CCrypt::Encrypt("RSK", 123);
比如:c1,c2是做什么用的;key移位后是什么,与字符异或后是什么;
两个for循环的计算步骤;设置str长度为2,那前面12是什么?
谢谢您的帮助!

[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

收藏
免费 5
支持
分享
最新回复 (2)
雪    币: 5340
活跃值: (598)
能力值: (RANK:170 )
在线值:
发帖
回帖
粉丝
2
这是一个简单的异或加密算法
这段函数分为两个部分,我们分别分析吧,呵呵
第一部分:
Result=S; // 初始化结果字符串
for(i=0; i<S.GetLength(); i++) // 依次对字符串中各字符进行操作
{
Result.SetAt(i, S.GetAt(i)^(Key>>8)); // 将密钥移位后与字符异或
Key = ((BYTE)Result.GetAt(i)+Key)*C1+C2; // 产生下一个密钥
}
S=Result; // 保存结果


①Result.SetAt(i, S.GetAt(i)^(Key>>8))
S.GetAt(i) 我们理解成 S[i] 就是明文第i个字母;
Key就是密钥
密钥右移8位与 S[i]做异或运算,得到的就是密文Result[i];
②Key = ((BYTE)Result.GetAt(i)+Key)*C1+C2;
将得到的密文Result[i]加上旧密钥 再与C1、C2做运算 得到第一个密钥。

解密算法为:
S=Result; // 初始化结果字符串
for(i=0; i<Result.GetLength(); i++) // 依次对字符串中各字符进行操作
{
S.SetAt(i, Result.GetAt(i)^(Key>>8)); // 将密钥移位后与字符异或
Key = ((BYTE)Result.GetAt(i)+Key)*C1+C2; // 产生下一个密钥
}
Result=S; // 保存结果

第二部分:
Result.Empty(); // 清除结果
for(i=0; i<S.GetLength(); i++) // 对加密结果进行转换
{
j=(BYTE)S.GetAt(i); // 提取字符
// 将字符转换为两个字母保存
str="12"; // 设置str长度为2
str.SetAt(0, 65+j/26);
str.SetAt(1, 65+j%26);
Result += str;
}

这部分就是让密文能显示成串的形式
比如
0x01 这个字符是不可能显示出来的。
经过第二部分处理就可以显示出来了 0x01会显示成AB

这部分解密很简单了,哈哈,我就不说了
2004-6-6 14:21
0
雪    币: 296
活跃值: (20)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
3
// 加密函数
CString Encrypt(CString S, WORD Key)
{
        CString Result (S);       

        // 依次对字符串中各字符进行操作
        for(int i = 0; i < S.GetLength(); i++)
        {
                // 将密钥移位后与字符异或
                Result.SetAt(i, S.GetAt(i) ^ ( Key >> 8 ) );

                // 产生下一个密钥
                Key = ((BYTE)Result.GetAt(i) + Key) * C1 + C2;
        }

        return Result;
}

CString DeEncrypt(CString S, WORD Key) // 加密函数
{
        CString Result(S);

        // 依次对字符串中各字符进行操作
        for(int i = 0; i < S.GetLength(); i++)
        {
                BYTE beforeL = S.GetAt(i);
                // 将密钥移位后与字符异或
                Result.SetAt(i, S.GetAt(i)^(Key >> 8));
               
                // 产生下一个密钥
                Key = (((BYTE)beforeL + Key ) * C1) + C2;
        }
       
        return Result;
}
已经测试过了。
2004-6-8 15:58
0
游客
登录 | 注册 方可回帖
返回
// // 统计代码