网络安全课程设计Java实现DES加密算法(可视化界面)代码+设计文档

一、DES加密/解密算法

DES是一种对称加密算法,DES算法明文分组长度为64 bit,秘钥长度也为64 bit,但是实际密钥长度只有56位,其中第8、16、24、32、40、48、56、64位是奇偶校验位,用于检查密钥在产生、分配及存储过程中可能发生的错误。

初始置换IP:利用初始置换对明文X进行换位处理,打乱原来的次序,得到一个乱序的64 bit 明文组。

子秘钥生成:在DES中,加密者输入的明文和密钥都是64 bit,其中只有56 bit是有用的位数(因为有8位为奇偶校验位)。但是DES加密过程有16轮循环函数,其中需要用到16个密钥,所以要将这56 bit密钥扩展生成16个48 bit 的子密钥。

轮函数:轮函数中将IP置换后的明文进行16次迭代,每个循环都使用我们之前计算的16个48 bit 密钥之一。

F函数:加密函数f是整个DES算法的核心。函数f如上图所示,函数以长度为32 的比特串 A = R(32 bit)作为第1个输入,以长度为48的比特串变元J = K(48 bit)作为第2个输入,产生的输出是长度为32的比特串。

位选择函数E:对第一个变元A,由给定的选择扩展函数可以将其扩展为48 比特串E(A)。

S盒代换:将 E(A) 和 K 进行异或操作后,把比特串分为8组,一组 6 bit,分别对每一组进行S盒代换。经过S盒,每一组由 6 bit 缩减为 4 bit。

S盒的行号从0到3,列号从0到15。

代换的过程如下,例如需要代换的第一组数据输入为011001,则第一位0和最后一位1组合成的01即为行号,中间的1101为列号,第一组数据对应S1,01转化成10进制为1,1101转化成10进制为13,因此S1中的第1行第13列就为对应的输出,查表得5,转化成2进制为0101。因此0101就为最终的4位输出。

P盒代换:P为固定置换,将经过S盒变换得到的32 bit进行一个置换操作,得到F函数的最终输出。

轮函数步骤:令+表示XOR加法 (模2诸位加法) ,进行16轮,得到R16和L16。

进行16轮,得到R16和L16。

逆初始置换IP-1:轮函数最后一步的左边32 bit和右边32 bit合成64 bit,再进行逆初始置换,得到最终密文。

DES解密:DES的解密过程与加密过程相同,只不过在16次迭代中使用子密钥的次序正好相反。解密时,第1次迭代使用子密钥K16,第2次使用子密钥K15,以此类推…,第16次使用子密钥K1。

加密流程:

解密流程: 


 

 

二、结果运行图

 

  • 2
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
10, 15, 6, 8, 0, 5, 9, 2, 6, 11, 13, 8, 1, 4, 10, 7, 9, 5, 0,好的,校园网网络安全课程设计是一个非常重要的课程,它可以帮助学生了 15, 14, 2, 3, 12 }, { 13, 2, 8,解网络安全的基本概念、原理和技术,并且掌握网络安全的实践技能。以下 4, 6, 15, 11, 1, 10, 9, 3, 14, 5是一些可能的课程设计主题和建议: 1. 网络安全基础知识的学习和实, 0, 12, 7, 1, 15, 13, 8, 10, 3, 7, 4, 12, 5, 6, 11, 0, 14, 9, 2践,包括网络拓扑结构、网络协议、网络攻击和防御技术等。 2. 网络安, 7, 11, 4, 1, 9, 12, 14, 2, 0,全漏洞的发现和利用,包括常见的漏洞类型、漏洞扫描和利用工具的 6, 10, 13, 15, 3, 5, 8, 2, 1, 使用等。 3. 网络安全事件的应急响应和管理,包括网络安全事件的分类、应急14, 7, 4, 10, 8, 13, 15, 12, 9, 0,响应流程、安全事件的调查和取证等。 4. 网络安全策略和管理,包括 3, 5, 6, 11 } }; // Permutation Table int permutation[] = { 16, 7, 20, 21, 29, 12, 28, 17, 1, 15, 网络安全政策的制定、实施和监督、安全管理标准的制定和实践等。 523, 26, 5, 18, 31, 10, 2, 8, 24, 14. 网络安全技术的研究和应用,包括密码学、网络安全认证和授权技术、, 32, 27, 3, 9, 19, 13, 30, 6, 22,安全审计技术等。 以上是一些课程设计的主题和建议,可以根据具体的情 11, 4, 25 }; // Key Permutation Table int key_permutation[] = { 57, 49况和需求进行选择和设计。同时,也可以考虑让学生参与到实际的网络安全项目中, 41, 33, 25, 17, 9, 1, 58, 50, 42,,提高他们的实践能力。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值