DES算法及其在VC++6.0下的实现(上)

摘要:

本文介绍了一种国际上通用的加密算法—DES算法的原理,并给出了在VC++6.0语言环境下实现的源代码。最后给出一个示例,以供参考。

关键字:DES算法、明文、密文、密钥、VC;

本文程序运行效果图如下:

正文:

当今社会是信息化的社会。为了适应社会对计算机数据安全保密越来越高的要求,美国国家标准局(NBS)于1997年公布了一个由IBM公司研制的一种加密算法,并且确定为非机要部门使用的数据加密标准,简称DES(Data Encrypton Standard)。自公布之日起,DES算法作为国际上商用保密通信和计算机通信的最常用算法,一直活跃在国际保密通信的舞台上,扮演了十分突出的角色。现将DES算法简单介绍一下,并给出实现DES算法的VC源代码。

DES算法由加密、解密和子密钥的生成三部分组成。

一.加密

DES算法处理的数据对象是一组64比特的明文串。设该明文串为m=m1m2…m64 (mi=0或1)。明文串经过64比特的密钥K来加密,最后生成长度为64比特的密文E。其加密过程图示如下:

DES算法加密过程

对DES算法加密过程图示的说明如下:待加密的64比特明文串m,经过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

该比特串被分为32位的L0和32位的R0两部分。R0子密钥K1(子密钥的生成将在后面讲)经过变换f(R0,K1)(f变换将在下面讲)输出32位的比特串f1,f1与L0做不进位的二进制加法运算。运算规则为:

时间: 2024-10-31 06:37:02

DES算法及其在VC++6.0下的实现(上)的相关文章

DES算法及其在VC++6.0下的实现(下)

在<DES算法及其在VC++6.0下的实现(上)>中主要介绍了DES算法的基本原理,下面让我们继续: 二.子密钥的生成 64比特的密钥生成16个48比特的子密钥.其生成过程见图: 子密钥生成过程具体解释如下: 64比特的密钥K,经过PC-1后,生成56比特的串.其下标如表所示: PC-1 57 49 41 33 25 17 9 1 58 50 42 34 26 18 10 2 59 51 43 35 27 19 11 3 60 52 44 36 63 55 47 39 31 23 15 7 6

在VC++6.0下可以运行,但是移植到VS2003之后就不行了

问题描述 用DBLibrary和数据库连接有一个例子physic在VC++6.0下可以运行,但是移植到VS2003之后就不行了,不知道为什么,应该怎么设置?程序地址见file:///E:/HLA/SQL/VC++中使用%20DB-Library%20编程(SQL%20Server)%20一/VC++中使用%20DB-Library%20编程(SQL%20Server)%20-%20VC知识库文章.htm 解决方案 解决方案二:属性里面设置静态链接

VS2013和codeblocks,VC++6.0在C/C++上编程有多大区别?

问题描述 VS2013和codeblocks,VC++6.0在C/C++上编程有多大区别? VS2013和codeblocks,VC++6.0在C/C++上编程有多大区别? 为什么有的代码在codeblocks和VC++6.0上完美运行,但在VS2013上总是报错或者失败退出? 解决方案 VS2013主要一个是使用unicode默认,一个是它支持C++ 11/14的新语法. 另外一些不安全的函数,比如scanf strcpy等默认被禁止使用(可以通过编译器开关允许) 解决方案二: 感觉VS201

在VC 6.0下如何调用Delphi开发的进程内COM

源代码包中共有两个zip文件,其中DelphiCallVCCOM.zip为Delphi调用VC的COM组件,VCCallDelphiCOM.zip为VC调用Delphi的COM组件 因为本人的语言水平很差,考大学时150的总分,我考了个60分.外语也是,初中及格过一次,会考及格过一次.其它的时间好像从没有及格过.所以我不写文章,因我一百字的文章给我写,至少要出八九个错别字.哈哈-.真是个马大哈.你别说我还真的姓马.所以下面的文章中有错误之处,请你老人家多多理解.谁叫你看我的文章了的.下面就谈正事

VC++ 6.0下GIS打印输出控制的实现

VC++6.0中用应用向导生成新程序时,可以在应用向导Step4对话框中选择Printing and Print preview选择包括了基本打印和打印预览支持.但这些打印功能在MM_TEXT模式下打印出的文件尺寸大小发生了变化,比屏幕上显示的小得多. 我们在VC++中实现绘图时最方便.最常用的绘图模式为MM_TEXT.如何对打印输出进行有效的控制?尤其是在GIS中,是我们经常所面临的问题.笔者通过实践,提出了自己的做法,再此与广大读者共同探讨. 首先明确的是在MM_TEXT模式下很难实现象素坐

在VC++ 6.0下利用消息实现内部进程通讯

内部进程间通讯和数据交换有多种方式:消息.共享内存.匿名(命名)管道 .邮槽.Windows套接字等多种技术.其中利用消息机制实现IPC虽然同其他方法 相比有交换的数据量小.携带的信息少等缺点,但由于其实现方便.应用灵活而 广泛应用于无须大量.频繁数据交换的内部进程通讯系统之中,尤其是对于在上 层主控软件与底层工作软件之间的命令与响应上更能充分显示其良好的性能.本文就通过编制一个主控软件和一个受其操作的底层工作软件来阐述如何用VC++6.0 通过消息来实现内部进程通信. 一.Windows消息机

如何实现DES算法

DES( Data En cryption Standard)算法,于1977年得到美国政府的正式许可,是一种用56位密钥来加密64位数据的方法.DES算法以被应用于许多需要安全加密的场合.(如:UNIX的密码算法就是以DES算法为基础的).下面是关于如何实现DES算法的语言性描述,如果您要其源代码,可以到Http//Assassin.yeah.net下载,后者您有任何问题也可以写信给我(Assassin@ynmail.com). 1-1.变换密钥 取得64位的密钥,每个第8位作为奇偶校验位.

《C语言课程设计》一1.1 VC 6.0简介

1.1 VC 6.0简介 Visual C++ 6.0是Microsoft公司推出的开发Win32程序的集成开发环境,可将"高级语言"翻译为"机器语言(低级语言)",并支持面向对象可视化编程.它具有程序框架自动生成.灵活方便的类管理.代码编写和界面设计集成交互操作.可开发多种程序等优点,而且通过简单的设置即可使其生成的程序框架支持数据库接口.OLE和WinSock网络. Visual C++ 6.0, 简称VC 6.0或VC 6,是微软公司于1998年推出的Visu

数据结构、c语言-急!!!!为何以下程序执行第2功能离开车厂后在vc++6.0环境下程序会报错并终止运行,求解决方案

问题描述 急!!!!为何以下程序执行第2功能离开车厂后在vc++6.0环境下程序会报错并终止运行,求解决方案 #include "stdafx.h" #include #include #include #define max 5 #define pri 5 typedef struct time{ int year; int day; int month; int hour; int min; }Time; typedef struct node{ char num[10]; Tim