欢迎来到天天文库
浏览记录
ID:38580155
大小:217.50 KB
页数:12页
时间:2019-06-15
《C语言DES加密算法》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、云南大学软件学院SchoolofSoftware,YunnanUniversity成绩学期:2011秋季学期课程名称:密码技术任课教师:学生姓名:学号:实验项目:实验二DES加密算法联系电话:电子邮件:完成提交时间:年月日密码技术实验报告实验项目:实验二,第2题实现DES对任意文件的加解密实验要求(内容)实现DES对任意文件的加解密,利用控制台对所有文件(中英文文本、符号甚至任意的文件)的加解密。加解密形式如下:cipher-e/-dkeyinputfileoutputfile说明:对于加密来说,输入文件名就是明文文件,对于
2、解密来说,输入文件名就是密文文件,注意文件读取方式和控制文件结束控制台编程:intmain(intargc,char*argv[])实验环境操作系统:win7编译环境:MicrosoftVisualStudio2010实现功能本次实验达到了题目的要求:实现了用DES实现控制台对任意文件的加解密,用键盘接收明文(密文)文件路径和密钥,然后再输入需要保存的密文(明文)文件路径,然后就可以把加解密后得到的密明文文件保存该路径下。程序主要采取对数据的位操作的形式,把明密文文件中的内容以字节为单位读取,每次读取8个byte共65bit
3、s,然后使用标准DES的算法依次对读取的64bits明密文进出加解密处理。主函数的操作也充分体现了程序的可操作性和健壮性,能够让用户自己选择相应的操作,比如加密、解密以及对程序的一些基本情况说明。但是对文件的路径的输入有比较严格的格式约束。如:盘符名:\文件名.txt格式错误则会导致文件打开失败,不能进行加解密操作。数据结构本次实验的程序较为复杂,涉及对位的操作。实验过程中用到的主要数据结构为数组和文件型指针,在实验中我定义了2个文件型指针FILE*fp1,*fp2,其中一个指向明文文件,一个指向密文文件。另外还定义了多个
4、字符数组,如charPlainfpath[260]声明字符数组存储明文文件的文件路径,charCipherfpath[260]声明字符数组存储密文文件的文件路径,charkey[100]声明字符数组存储密钥。对于读取出来的数据均以unsignedchar的类型进行处理。这个程序的实现比较复杂的是对位的操作,主要包括取位值、移位和异或等,在对位的操作还主要用到了memcpy函数对unsignedchar类型的字符串进行复制,除此之外没有采用更多的数据结构。程序流程程序模块结构图:开始start选择操作解密函数退出程序加密函数用
5、户输入明密文文件路径和密钥明(密)文文件是否能打开退出程序对打开的文件进行操作,每次取出长度为8个byte的明密文。将8byte的明密文和密钥转换为64bits明密文进行初始置换IP密钥进行置换选择1循环左移和置换选择2产生子密钥分成左右两部分进入F函数右半部分在F函数里依次进行扩展置换、与子密钥异或、S盒置换和P置换经F函数处理的与左半部分异或后成右半部分,原先的右半部分作为左半部分32bits对换,然后进行逆初始置换将结果由64bits转换成8byte,然后写入文件保存main()函数的调用关系:Encrypt()Dec
6、rypt()Explain()Block_Decrypt()Block_Encrypt()L_Shift()R_Shift()BToC()CToB()F_function()函数的接口:voidEncrypt(char*Plainfpath,char*Cipherfpath,unsignedchar*Keys);//加密函数voidDecrypt(char*Cipherfpath,char*Plainfpath,unsignedchar*Keys);//解密函数voidBlock_Encrypt(unsignedchar*P
7、lain,unsignedchar*Cipher,unsignedchar*Key);//分组加密函数voidBlock_Decrypt(unsignedchar*Cipher,unsignedchar*Plain,unsignedchar*Key);//分组加密函数voidCToB(unsignedchar*C_String,unsignedchar*B_String);//将字符类型转换成二进制类型的函数voidBToC(unsignedchar*B_String,unsignedchar*C_String);//将二进
8、制类型转换成字符类型的函数voidL_Shift(unsignedchar*PC_Key,intcount);//加密中循环左移函数voidR_Shift(unsignedchar*PC_Key,intcount);//解密中循环右移函数voidF_function(unsignedcha
此文档下载收益归作者所有