简化DES加密算法
des算法s合计算规则

des算法s合计算规则摘要:1.算法简介2.目标与策略3.算法实现4.应用场景5.总结与展望正文:1.算法简介DES算法是一种对称加密算法,它基于密钥对数据进行加密和解密。
DES 算法采用64位密钥,其中8位用于奇偶校验,用户实际可用的密钥长度为56位。
DES算法的加密过程包括分组、置换、S盒替换和P盒替换等步骤。
解密过程与加密过程相反。
2.目标与策略DES算法的主要目标是实现快速、安全的加密和解密。
为了达到这个目标,DES算法采用了对称密钥体制,即加密和解密使用相同的密钥。
同时,DES算法采用了各种复杂的算法设计策略,如S盒替换和P盒替换等,以增强加密强度。
3.算法实现DES算法的实现过程分为以下几个步骤:(1) 分组:将明文或密文分成64位一组,不足64位的,在末尾用0补足。
(2) 置换:将每组的第8位与第7位进行交换,然后将第1位与第6位、第2位与第5位、第3位与第4位进行交换。
(3) S盒替换:将经过置换后的64位数据分成8组,每组8位,然后通过查表的方式,将每组的8位数据替换为对应的S盒替换值。
(4) P盒替换:将经过S盒替换后的数据,再进行一次P盒替换。
P盒替换是根据置换后的数据与密钥的对应关系进行替换。
(5) 加密/解密:将替换后的数据进行16轮加密(或解密),每轮加密(或解密)包括一个S盒替换和一个P盒替换。
(6) 输出:加密后的数据或解密后的数据。
4.应用场景DES算法广泛应用于网络通信、数据存储等领域,为用户提供安全的数据加密和解密服务。
由于DES算法的密钥长度较短,随着计算机技术的发展,DES算法的安全性逐渐降低。
目前,DES算法主要用于低安全需求的场景,如内部通信等。
5.总结与展望DES算法作为对称加密算法的代表,曾在信息安全领域发挥了重要作用。
然而,随着计算机技术的发展和加密算法的不断进步,DES算法的安全性逐渐降低,已不再是信息安全领域的首选加密算法。
des加解密算法原理

des加解密算法原理DES(Data Encryption Standard)是一种基于对称加密算法的加解密技术,被广泛应用于计算机和网络安全领域。
它采用分组密码的设计思想,将明文分成64位的数据块,并使用密钥对其进行加密和解密操作。
下面我们将详细介绍DES算法的原理和应用。
DES算法的原理可以分为四个主要步骤:初始置换、16轮迭代、逆初始置换和子密钥生成。
首先是初始置换,将输入的64位明文根据所定义的置换表进行重排,以加强加密的随机性和扩散性。
这一步骤的目的是为了消除输入数据之间的相关性,使其在进入加密过程之前更具随机性。
接下来是16轮迭代,每一轮迭代都包括四个主要步骤:扩展置换、密钥与明文异或、S盒置换和置换函数。
扩展置换将32位数据扩展为48位,以使之与扩展后的子密钥进行异或运算。
然后,将异或结果分为8个组,每个组经过S盒代替置换,将6位数据映射为4位数据,增加了加密的复杂性。
最后,经过置换函数进行置换操作。
第三步是逆初始置换,将经过16轮迭代后得到的数据根据逆置换表进行重排,以得到最终的密文。
逆初始置换是初始置换的逆运算,用于恢复密文的顺序,使之与明文对应。
最后是子密钥的生成,根据输入的64位密钥经过置换和位移操作生成16个48位的子密钥。
每轮迭代都使用一个子密钥,通过改变子密钥可以增加加密的随机性,从而提高安全性。
DES算法的应用广泛,主要用于网络通信中的数据加密保护。
例如,在银行系统中,通过DES算法可以对用户的敏感信息进行加密,保护用户的财产安全。
在电子商务领域,通过DES算法可以对在线交易的数据进行加密,防止黑客窃取用户的个人信息和银行卡号。
此外,DES算法还常用于数据库加密、文件加密和数据传输等领域,以确保机密信息的安全性。
总之,DES算法是一种经典的对称加密算法,通过初始置换、16轮迭代、逆初始置换和子密钥生成四个步骤,实现了对数据的加密和解密操作。
它具有较高的安全性和广泛的应用领域,是保护计算机和网络安全的重要工具。
DES算法

DES算法一、DES算法DES算法为密码体制中的对称密码体制,又被成为美国数据加密标准,是1972年美国IBM 公司研制的对称密码体制加密算法。
明文按64位进行分组, 密钥长64位,密钥事实上是56位参与DES运算(第8、16、24、32、40、48、56、64位是校验位,使得每个密钥都有奇数个1)分组后的明文组和56位的密钥按位替代或交换的方法形成密文组的加密方法。
DES加密算法特点:分组比较短、密钥太短、密码生命周期短、运算速度较慢。
DES工作的基本原理是,其入口参数有三个:key、data、mode。
key为加密解密使用的密钥,data为加密解密的数据,mode为其工作模式。
当模式为加密模式时,明文按照64位进行分组,形成明文组,key用于对数据加密,当模式为解密模式时,key用于对数据解密。
实际运用中,密钥只用到了64位中的56位,这样才具有高的安全性。
DES算法把64位的明文输入块变为64位的密文输出块,它所使用的密钥也是64位,整个算法的主流程图如下:其功能是把输入的64位数据块按位重新组合,并把输出分为L0、R0两部分,每部分各长32位,其置换规则见下表: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,即将输入的第58位换到第一位,第50位换到第2位,...,依此类推,最后一位是原来的第7位。
L0、R0则是换位输出后的两部分,L0是输出的左32位,R0 是右32位,例:设置换前的输入值为D1D2D3......D64,则经过初始置换后的结果为:L0=D58D50...D8;R0=D57D49 (7)经过16次迭代运算后。
des算法s合计算规则

des算法s合计算规则(原创版)目录1.DES 算法简介2.DES 算法的加密规则3.DES 算法的解密规则4.DES 算法的优缺点正文1.DES 算法简介DES(Data Encryption Standard)算法是一种对称密钥加密标准,由美国国家标准局(NIST)于 1977 年制定。
DES 算法是一种分组密码,其密钥长度为 56 位,分组长度为 64 位。
由于其加密速度快、安全性高,DES 算法在过去被广泛应用于各种数据加密场景。
2.DES 算法的加密规则DES 算法的加密过程分为以下步骤:(1)初始化:设置初始向量(IV)和密钥(K)。
(2)分组替换:将明文分组(64 位)与密钥(56 位)进行异或操作,得到密文分组(64 位)。
(3)S 盒替换:将密文分组中的每个字节替换为特定的 S 盒中的字节,共有 16 个 S 盒,每个 S 盒包含 96 个替换规则。
(4)Mixing:对 S 盒替换后的密文分组进行 16 轮的 Mixing 操作,每轮包括 F 函数、左旋转、右旋转和异或操作。
(5)最终置换:对 Mixing 操作后的密文分组进行重新排列,得到最终的密文。
3.DES 算法的解密规则DES 算法的解密过程与加密过程相反,需要使用相同的密钥和初始向量,按照以下步骤进行:(1)逆置换:对密文进行逆排列,得到明文分组。
(2)逆 Mixing:对逆置换后的明文分组进行 16 轮的逆 Mixing 操作。
(3)S 盒逆替换:将逆 Mixing 操作后的明文分组中的每个字节替换回原来的 S 盒中的字节。
(4)分组替换:将 S 盒逆替换后的明文分组与密钥进行异或操作,得到原始明文分组。
4.DES 算法的优缺点优点:加密速度快,安全性较高,适用于各种数据加密场景。
缺点:密钥长度较短,容易受到暴力破解攻击;同时,S 盒的设计存在一定的漏洞,可能会被攻击者利用。
DES 加密算法的改进方案

1DES 算法DES 算法是一种分组密码,明文每64 比特为一组,密钥为64 比特,除去8 比特奇偶校验位,实际密钥为56 比特,因此密钥组合数量为256 个。
加密时,用同一密钥依次对每组明文进行加密,得到的每组密文也是64 比特,因此最后得到的密文长度和明文长度一致。
对每组等长明文加密时,密钥不变,算法也不变,因此DES 十分适合以嵌入式硬件实现。
DES 加密前先把明文用一个置换函数IP 映射为初始密文。
DES 加密算法由16 轮迭代加密构成,每次迭代加密所用密钥由原始密钥循环左移得到,称为子密钥K 。
每轮迭代前,把上一轮迭代得到的密文(如果是第一轮迭代,加密对象是初始密文)分为左半L(第1~32 位)和右半R(第33~64 位)。
R 被当前子密钥加密为f (R, K) ,f 为加密函数。
f (R, K) 和L 异或运算后得到下一轮迭代的右半R' 。
下一轮迭代的左半L' 由R 赋值,和R 完全一致。
16 轮迭代完成后得到的密文,经过一个置换函数映射后得到最终密文。
解密算法和加密算法一致,密钥也一致,但每轮迭代所使用的子密钥的顺序和加密时相反。
经过16 轮迭代的DES 算法已被证明具有充分的对抗统计分析和线性分析的能力。
因此,破解16 轮迭代的DES 密文的唯一途径是暴力破解,即用穷举法尝试所有的256 个可能的密钥[7],这在DES 算法刚提出时被认为是不可能完成的任务。
但随着计算机运算速度的提高和并行计算技术的成熟,DES 的安全度被大大弱化。
2DES 算法的改进方案对DES 算法的改进原则是使用RSA 保护DES 密钥,同时在加密前,对明文增加乱序和干扰处理。
2.1 改进方案的总体设计DES 算法的密钥是对称密钥,必须通过秘密信道传送。
为了使其也能通过互联网等公开信道传送,必须使用公钥密码体系对其进行保护。
最常用的公钥密码算法是RSA,因此,我们可以把DES 密钥“封装”在一个RSA 加密的“头部”(Header)里,然后把这个头部附加在DES 密文前,成为一个密文包(Encrypted Data Packet),再把这个密文包发送给接收方。
DES加密的算法

信息安全概论·课程设计DES加密的C语言实现目录摘要....................................................... 错误!未定义书签。
Abstract ................................................... 错误!未定义书签。
关键词..................................................... 错误!未定义书签。
1.算法描述................................................ 错误!未定义书签。
1.1加/解密算法的一般原理............................... 错误!未定义书签。
1.2加/解密机制的应用................................... 错误!未定义书签。
2.S盒设计................................................ 错误!未定义书签。
3.DES程序实例与分析...................................... 错误!未定义书签。
4.DES实例运行结果........................................ 错误!未定义书签。
5.结语.................................................... 错误!未定义书签。
6.参考文献................................................. 错误!未定义书签。
信息安全概论·课程设计DES加密的C语言实现C language achieve DES algorithm摘要DES算法是一种数据加密算法,自从1977年公布以来,一直是国际上的商用保密通信和计算机通信的最常用的加密标准。
des 数据加密标准
des 数据加密标准数据加密标准(DES)是一种对称密钥加密算法,它是一种广泛使用的加密标准,被认为是数据加密领域的基石之一。
DES使用56位密钥对64位的数据块进行加密,其加密过程包括初始置换、16轮迭代运算和最终置换。
DES的安全性曾经受到一些质疑,因为56位密钥的长度相对较短,容易受到暴力破解的攻击。
随着计算机技术的发展,DES的加密强度逐渐变弱,因此,现在已经不推荐将DES用于新的应用程序中。
为了解决DES加密强度不足的问题,后续出现了3DES和AES等更加安全的加密算法。
3DES是对DES的改进,它使用了两个或三个56位密钥,对数据进行三次加密,加强了加密的强度。
而AES则是一种高级加密标准,它支持128位、192位和256位的密钥长度,加密强度更高,被广泛应用于各种领域。
尽管DES的安全性已经受到质疑,但它作为历史上的重要加密标准,仍然有着重要的意义。
许多旧系统和遗留应用程序仍在使用DES加密算法,因此了解DES的工作原理和安全特性仍然是必要的。
同时,DES的设计思想和加密原理也为后续的加密算法提供了重要的参考和借鉴。
在实际应用中,DES的加密强度虽然不如3DES和AES,但在一些对加密强度要求不高的场景下,仍然可以使用DES。
例如,内部数据传输、低价值数据的加密存储等场景,DES仍然可以发挥作用。
但在对安全性要求较高的场景下,建议使用更加安全的加密算法,以确保数据的安全性。
总的来说,DES作为早期的加密标准,为后续的加密算法发展和应用奠定了基础。
尽管它的加密强度相对较弱,但在一些特定场景下仍然有其存在的价值。
然而,随着计算机技术的不断发展,我们需要不断地关注加密算法的安全性,并选择合适的加密算法来保护数据的安全。
希望未来能够出现更加安全、高效的加密算法,为数据安全保驾护航。
DES加密算法.
数据加密标准DES(Data Encryption Standard)算法是由美国IBM公司研制的一种分组密码算法,一种迭代分组密码。
DES是一种使用最为广泛的加密算法,虽然DES出现后又产生了许多常规加密算法,但DES仍是此类算法中最重要的一种。
在正式讨论DES算法之前,为了更好的理解算法的实际工作过程,我们先来看一个简化的DES算法,以此加深对DES算法的理解。
一、简化的DES加密算法简化的DES加密算法是以8bit的明文分组和10bit密钥作为输入,产生8bit 密文分组作为输出。
1、加密流程简化的DES算法基本加密流程如图6.9所示图6.9 简化的DES的加密过程2、加密算法构成:函数、SW置换函简单DES的加密算法包括4个基本函数:初始置换函数IP、fk数、逆置换函数IP-1。
(1)初始置换函数IP初始置换IP是将明文中数据的排列顺序按一定的规则重新排列,而生成新的数据序列的过程。
如图6.10所示:8bit原数据位置 1 2 3 4 5 6 7 8【IP置换】经IP置换后的数据位置 2 6 3 1 4 8 5 7图6.10 简单DES的初始置换例:设8bit数据为11110011 ,则初始置换后的结果为:函数f k函数是多个置换函数和替代函数的组合函数。
f k函数首先将输(2) fk入它的8bit数据进行分组,分成左4位和右4位,然后对右组的4位数据进行E/P扩展置换运算,接着将扩展置换所得的8bit数据与子密钥进行异或运算,再将异或运算所得结果通过S盒输出,再将通过S盒输出的数据进行P4置换,最后将经过P4置换后的数据与输入f函数经分组的左4位数据进行异或运算。
kF(R,SK)函数是f k函数的核心函数,其中SK是子密钥。
F(R,SK)函数的运算方法如下:f k(L,R)=(L⊕F(R,SK),R)L:输入的左边4位分组 R:输入的右边4位分组⊕:逐位异或①扩展/置换是将4bit输入数据经过置换和扩展而产生8bit数据的算法。
DES算法的实现及安全性分析
DES算法的实现及安全性分析DES(Data Encryption Standard)是一种对称加密算法,用于加密和解密数据。
DES是一种块加密算法,将输入数据分成64位的块进行加密,输出64位的密文。
DES算法使用一个64位的密钥来加密和解密数据,这个密钥包含56位的有效位和8位的奇偶校验位。
在DES算法中,加密和解密使用相同的密钥。
1.原始数据处理:如果数据长度不是64位的倍数,需要进行填充操作,通常使用0填充。
2.密钥生成:根据输入密钥,生成加密和解密使用的子密钥。
DES算法使用56位的原始密钥生成16个48位的子密钥,每个子密钥用于单个加密轮次。
3.初始置换:将64位输入数据按照DES算法的规则进行初始置换。
4.16轮加密:将初始置换后的数据分为左右两部分,每一轮使用一轮加密函数对左半部分进行处理,并将结果与右半部分异或,然后将左右部分交换。
5.逆初始置换:经过16轮加密后的数据进行逆初始置换,得到加密后的64位密文。
6.解密:将加密后的密文按照相反的顺序使用16轮解密函数进行解密处理,得到解密后的原始数据。
DES算法的安全性主要基于密钥长度和算法结构。
DES密钥长度较短,只有56位有效位,因此在今天的计算能力下,使用穷举法破解DES密码是可行的。
此外,DES算法的结构已经被一些攻击方法所破解,例如差分攻击和线性攻击。
为了解决DES算法的安全性问题,目前使用更加安全和强大的替代算法,例如AES(Advanced Encryption Standard)算法。
AES算法使用128位、192位或256位的密钥长度,提供了更高的安全性。
AES已经成为目前最广泛使用的对称加密算法之一总的来说,DES算法在当今的环境中已经不够安全,因为其密钥长度较短,结构容易受到攻击。
建议在实际应用中使用更加安全的替代算法,如AES算法。
如果有特殊需求要使用DES算法,可以考虑使用3DES (Triple DES)算法,即对数据进行三次DES加密。
常见的加密和解密算法—DES
常见的加密和解密算法—DES⼀、DES加密概述 DES全称为Data Encryption Standard,即数据加密标准,是⼀种使⽤的块算法,1977年被的国家标准局确定为(FIPS),并授权在⾮密级政府通信中使⽤,随后该算法在国际上⼴泛流传开来。
需要注意的是,在某些⽂献中,作为算法的DES称为数据加密算法(Data Encryption Algorithm,DEA),已与作为标准的DES区分开来。
DES⼊⼝参数DES算法的⼊⼝参数有三个:Key、Data、Mode。
其中Key为7个字节共56位,是DES算法的⼯作密钥;Data为8个字节64位,是要被加密或被解密的数据;Mode为DES的⼯作⽅式,有两种:加密或解密。
DES基本原则DES设计中使⽤了分组密码设计的两个原则:混淆(confusion)和扩散(diffusion),其⽬的是抗击敌⼿对密码系统的统计分析。
混淆是使密⽂的统计特性与密钥的取值之间的关系尽可能复杂化,以使密钥和明⽂以及密⽂之间的依赖性对密码分析者来说是⽆法利⽤的。
扩散的作⽤就是将每⼀位明⽂的影响尽可能迅速地作⽤到较多的输出密⽂位中,以便在⼤量的密⽂中消除明⽂的统计结构,并且使每⼀位密钥的影响尽可能迅速地扩展到较多的密⽂位中,以防对密钥进⾏逐段破译。
DES与3DES的区别和联系3DES(即Triple DES)是DES向AES过渡的,它使⽤3条56位的密钥对数据进⾏三次加密。
是DES的⼀个更安全的变形。
它以DES为基本模块,通过组合分组⽅法设计出分组加密算法。
⽐起最初的DES,3DES更为安全。
该⽅法使⽤两个密钥,执⾏三次DES算法,加密的过程是加密-解密-加密,解密的过程是解密-加密-解密。
3DES加密过程为:C=Ek3(Dk2(Ek1(P))) 3DES解密过程为:P=Dk1(EK2(Dk3(C))) 采⽤两个密钥进⾏三重加密的好处有: ①两个密钥合起来有效密钥长度有112bit,可以满⾜商业应⽤的需要,若采⽤总长为168bit的三个密钥,会产⽣不必要的开销。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
数据加密标准DES(Data Encryption Standard)算法是由美国IBM公司研制的一种分组密码算法,一种迭代分组密码。
DES是一种使用最为广泛的加密算法,虽然DES出现后又产生了许多常规加密算法,但DES仍是此类算法中最重要的一种。
在正式讨论DES算法之前,为了更好的理解算法的实际工作过程,我们先来看一个简化的DES算法,以此加深对DES算法的理解。
一、简化的DES加密算法
简化的DES加密算法是以8bit的明文分组和10bit密钥作为输入,产生8bit 密文分组作为输出。
1、加密流程
简化的DES算法基本加密流程如图6.9所示
图6.9 简化的DES的加密过程
2、加密算法构成:
函数、SW置换函简单DES的加密算法包括4个基本函数:初始置换函数IP、f
k
数、逆置换函数IP-1。
(1)初始置换函数IP
初始置换IP是将明文中数据的排列顺序按一定的规则重新排列,而生成新的数据序列的过程。
如图6.10所示:
8bit原数据位置 1 2 3 4 5 6 7 8
【IP置换】
经IP置换后的数据位置 2 6 3 1 4 8 5 7
图6.10 简单DES的初始置换
例:设8bit数据为11110011 ,则初始置换后的结果为:
函数f k函数是多个置换函数和替代函数的组合函数。
f k函数首先将输(2) f
k
入它的8bit数据进行分组,分成左4位和右4位,然后对右组的4位数据进行E/P扩展置换运算,接着将扩展置换所得的8bit数据与子密钥进行异或运算,再将异或运算所得结果通过S盒输出,再将通过S盒输出的数据进行P4置换,最后将经过P4置换后的数据与输入f
函数经分组的左4位数据进行异或运算。
k
F(R,SK)函数是f k函数的核心函数,其中SK是子密钥。
F(R,SK)函数的运算方法如下:f k(L,R)=(L⊕F(R,SK),R)L:输入的左边4位分组 R:输入的右边4位分组⊕:逐位异或
①扩展/置换是将4bit输入数据经过置换和扩展而产生8bit数据的算法。
如图6.11所示:
E/P扩展置换前 1 2 3 4
E/P扩展置换
E/P扩展置换后 4 1 2 3 2 3 4 1
图6.11 简单DES的扩展/置换
②经扩展置换所得的8位数据与8位子密钥SK进行逐位异或运算
异或运算规则如图6.12所示。
图6.12 异或运算
即相同数据异或运算的结果为0,不同数据异或运算的结果为1。
例:
A:1 1 1 0 1 0 1 1
⊕
B:1 0 1 0 0 1 0 0
异或运算的结果:0 1 0 0 1 1 1 1
③S盒输出
简化DES算法使用两个S盒S0和S1。
如图6.13所示。
其运算方法是将输入S 盒的8bit数据从左至右按顺序分成左右两组,每组各4bit,左4bit数据输入S0盒,右4bit输入S1盒,如输入S盒的01001111分成0100和1111两组,对于每一组的第1bit和第4bit作为一个2bit数据并转化成一个十进制数据,这个数据用来指定S盒的一行。
第2bit和第3bit作为一个2bit数据并转化成一个十进制数据,这个数据用来指定S盒的一列。
将对应S盒中该行该列的十进制数据转化成二进制数据,即为S盒的2bit输出数据。
如:输入S0盒的数据为0100,则P1为0,P2为1,P3为0,P4为0,所以P1P4即00转化为0指定S0盒的第一行,P2P3即10转化为2指定S0盒的第三列,所得数据为3,转化为二进制为11,即从S0盒输出的2bit数据为11;输入S1盒的数据为1111,则P5为1,P6为1,P7为1,P8为1,所以P5P8即11转化为3指定S1盒的第四行,P6P7即11转化为3指定S1盒的第四列,所得数据为3,转化为二进制为11,即从S1盒输出的2bit数据为11,。
因此通过S盒输出的数据为1111。
S0盒 S1盒
1 0 3
2 0 1 2 3
3 2 1 0 2 0 1 3
0 2 1 3 3 0 1 0
3 1 3 2 2 1 0 3
图6.13 S盒
图6.14 S盒运算
④P4置换
由S0和S1产生的4bit数据经P4置换,产生4bit数据的输出。
P4置换的方法如图6.15所示。
置换前数据位置: 1 2 3 4
P4置换
置换后数据位置: 2 4 3 1
图6.15 P4置换
(3)交换函数(SW)
交换函数SW是将8bit输入数据的左四位与右四位交换位置之后产生8bit数据的输出。
其运算方法如图6.16所示。
交换前:1011 1101
交换后:1101 1011
(4)逆置换函数IP-1
逆置换函数IP-1是将8bit输入数据置换为8bit数据输出。
其运算方法如图6.17所示。
置换前位置: 1 2 3 4 5 6 7 8
IP-1 置换
置换后位置: 4 1 3 5 7 2 8 6
图6.17 逆置换函数IP-1
3、子密钥生成
简化DES的密钥是使用一个发送方和接收方共享的10bit密钥。
运算中使用的两个8bit子密钥就是通过这个10bit密钥生成。
输入:10bit密钥
输出:两个8bit子密钥(K1和K2)
(1)子密钥生成流程
简化DES的两个8bit子密钥的生成过程如图6.18所示。
(2)算法构成
简化DES的子密钥生成算法主要由置换函数P10和置换函数P8这两个置换函数加上【循环左移】构成。
设10bit数据从左到右依次为(k1,k2,k3,k4,k5,k6,k7,k8,k9,k10)则置换方式如图6.19所示。
P10(k1,k2,k3,k4,k5,k6,k7,k8,k9,k10)=(k3,k5,k2,k7,k4,k10,k1,k9,k8,k6,)
P8(k1,k2,k3,k4,k5,k6,k7,k8,k9,k10)=(k6,k3,k7,k4,k8,k5,k10,k9)
P10置换前数据位置:1 2 3 4 5 6 7 8 9 10
P10置换
P10置换后数据位置:3 5 2 7 4 10 1 9 8 6
P8置换前数据位置:1 2 3 4 5 6 7 8 9 10
P8置换
P8置换后数据位置: 6 3 7 4 8 5 10 9
图6.19 P10和P8置换
(3)子密钥生成
设密钥为1010000010 ,则子密钥的生成过程如图6.20所示。
4、加密过程举例
设8bit明文为11110011,使用前例中的子密钥进行加密,其过程如图6.21所示.。