加密技术(学习笔记=)Caesar算法
一个传统的算法(拥有2000年历史)非常古老的算法,就是字母移动位..
比如:
//--直接让字符串+偏移位(甚至可以减去偏移位)
char aaa = Convert.ToChar(('中'+2) );
Console.WriteLine(aaa);
//---解密的时候反转就可以了
char bbc = Convert.ToChar(((aaa) - 2));
但是这就设计到一个问题,可以用反转的方式,比如说让所有的字符串减几来推测,可能的明文,这样不安全的说.
for(int a=0;a<100;a++)
{
//----看这里就可以循环破译了
char bbc = Convert.ToChar(((aaa) - a));
}
修改下 针对上面的破译可以有通过随机函数针对每一位进行偏移- -这时候就需要一个对应的偏移key记录偏移顺序的阿阿
关键点:
RandomNumberGenerator rng = new RNGCryptoServiceProvider(); 生成随机 数组
对随机数组+上原文
for (int i = 0; i < Key.Length; i++)
{
if (Key[i] < 2)
{
Key[i] = 2;
}
sb[i] = (char)(sb[i] + Key[i]);
}
CaesarRandom
调用