站内搜索
广告
安全知识 当前各种加密方案完全解析
作者:    来源:    点击:    日期:2007-10-12 15:37:19   
  加密时所产生的伪随机序列是很随意的,可以设计成想要的任何序列。没有关于这个随机序列的详细的信息,解密密文是不现实的。例如:一些ASCII码的序列,如“eeeeeeee"可能被转化成一些随机的没有任何意义的乱码,每一个字节都依赖于其前一个字节的密文,而不是实际的值。对于任一个单个的字符的这种变换来说,隐藏了加密数据的有效的真正的长度。

  如果确实不理解如何来产生一个随机数序列,就考虑FIBBONACCI数列,使用2个双字(64位)的数作为产生随机数的种子,再加上第三个双字来做XOR操作。 这个算法产生了一系列的随机数。算法如下:

  unsigned long dw1, dw2, dw3, dwMask;

  int i1;

  unsigned long aRandom[256];

  dw1 = {seed #1};

  dw2 = {seed #2};

  dwMask = {seed #3};

  // this gives you 3 32-bit "seeds", or 96 bits total

  for(i1=0; i1 < 256; i1++)

  {

  dw3 = (dw1 + dw2) ^ dwMask;

  aRandom[i1] = dw3;

  dw1 = dw2;

  dw2 = dw3;

  }

  如果想产生一系列的随机数字,比如说,在0和列表中所有的随机数之间的一些数,就可以使用下面的方法:

  int __cdecl MySortProc(void *p1, void *p2)

  {

  unsigned long **pp1 = (unsigned long **)p1;

  unsigned long **pp2 = (unsigned long **)p2;

  if(**pp1 < **pp2)

  return(-1);

  else if(**pp1 > *pp2)

  return(1);

  return(0);

  }

  ...

  int i1;

  unsigned long *apRandom[256];

  unsigned long aRandom[256]; // same array as before, in this case

  int aResult[256]; // results go here

  for(i1=0; i1 < 256; i1++)

  {

  apRandom[i1] = aRandom + i1;

  }

  // now sort it

  qsort(apRandom, 256, sizeof(*apRandom), MySortProc);

  // final step - offsets for pointers are placed into output array

  for(i1=0; i1 < 256; i1++)

  {

  aResult[i1] = (int)(apRandom[i1] - aRandom);

  }

  ...

  变量'aResult'中的值应该是一个排过序的唯一的一系列的整数的数组,整数的值的范围均在0到255之间。这样一个数组是非常有用的,例如:对一个字节对字节的转换表,就可以很容易并且非常可靠的来产生一个短的密钥(经常作为一些随机数的种子)。这样一个表还有其他的用处,比如说:来产生一个随机的字符,计算机游戏中一个物体的随机的位置等等。上面的例子就其本身而言并没有构成一个加密算法,只是加密算法一个组成部分。

  作为一个测试,开发了一个应用程序来测试上面所描述的加密算法。程序本身都经过了几次的优化和修改,来提高随机数的真正的随机性和防止会产生一些短的可重复的用于加密的随机数。用这个程序来加密一个文件,破解这个文件可能会需要非常巨大的时间以至于在现实上是不可能的。

  四、结论

  由于在现实生活中,我们要确保一些敏感的数据只能被有相应权限的人看到,要确保信息在传输的过程中不会被篡改,截取,这就需要很多的安全系统大量的应用于政府、大公司以及个人系统。数据加密是肯定可以被破解的,但我们所想要的是一个特定时期的安全,也就是说,密文的破解应该是足够的困难,在现实上是不可能的,尤其是短时间内。

首页 上一页 [3] [4] [5]  下一页 尾页 
安全知识 当前各种加密方案完全解析 评论