DES 加密解密 ( C语言实现 )



 Des算法介绍: http://zh.wikipedia.org/wiki/DES

维基百科中des算法的介绍很详细了.

 

 

1轮的 des 采用 56 位有效的密钥(密钥本来是64位,其中第8,16,24,32,40,48,56,64位不影响结果) 对 64 位(8字节) 数据 进行加密, 加密解密算法是统一算法(过程一样,使用密钥次序不同)。

 

算法过程:

概述:

通过图比较容易 理解

 

 

① 算法开始对 输入数据进行初始的位置换 , IBM 已经给出置换表(下面大量置换都是查表置换 )置换之后得到初始数据。

{

置换表:

  char table_IP[]    /* 初始置换表 IP */
   = { 
    58, 50, 42, 34, 26, 18, 10,  2, 60, 52, 44, 36, 28, 20, 12,  4,
    62, 54, 46, 38, 30, 22, 14,  6, 64, 56, 48, 40, 32, 24, 16,  8,
    57, 49, 41, 33, 25, 17,  9,  1, 59, 51, 43, 35, 27, 19, 11,  3, 
    61, 53, 45, 37, 29, 21, 13,  5, 63, 55, 47, 39, 31, 23, 15,  7 
   };

   所以现在查表一位一位置换,比如 :

   原始数据存在 data1-data64 这 64 位中,置换后数据存在 to1 - to64 中:

   则有: to1 = data58, to2 = data50, to42 = data42 ... to64 = data7 .

   这样就可以得到新数据。

 

}//第一步结束

              

  • 3
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值