对称密码算法DES.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

实验一对称密码算法DES

一、实验目的

通过用DES算法对实际的数据进行加密和解密来深刻了解DES的运行原理。

二、实验环境

运行Windows或Linux操作系统的PC机,具有gcc(Linux)、VC(Windows)等C语言编译环境。

三、实验报告要求

〔1〕使用附录提供的程序对一个文件进行加密和解密,提交程序代码和执行结果。

〔2〕使用附录提供的程序对输入的十六进制数加密〔把输入的字符转化成整数。例如,输入两个字符1F,转化成二进制数000lllll〕,比拟输入和输出。当把输入的数改变一个位时〔如把1F变为1E〕,比拟输出的变化,并说明原因。

四、实验内容和步骤

〔1〕使用附录提供的程序对一个文件进行加密和解密,程序代码和执行结果如下所示。

程序代码:

intmain(intargc,char*argv[])

{

//定义一个文件输入流类对象infile

ifstreaminfile(Arthas.txt,ios::in);

if(infile==0){

cout出错啦!!endl;

exit(1);

}

//定义一个文件输出流类对象outfile

ofstreamoutfile(encreption.txt,ios::out);

if(outfile==0){

cout错啦!endl;

exit(1);

}

//定义一些变量

inti=0;

unsignedcharplain[9]encreption[9]key[8]={a,b,c,d,a,b,c,d};

symmetric_keyskey;

des_setup(key,8,0,skey);

// des_ecb_encrypt(pt,ct,skey);

while(infile.eof()!=1){

infileplain[i];

i++;

if(i==8){

plain[9]=\0;

des_ecb_encrypt(plain,encreption,skey);

for(intj=0;j8;j++)

outfileencreption[j];

//outfile\0;

i=0;

}

}

for(;i9;i++)

plain[i]=;

plain[9]=\0;

des_ecb_encrypt(plain,encreption,skey);

for(intj=0;j8;j++)

outfileencreption[j];

//outfile\0;

infile.close();

outfile.close();

//解密

ifstreaminfile1(encreption.txt,ios::in);

if(infile1==0){

cout出错啦!!endl;

exit(1);

}

ofstreamoutfile1(encreption1.txt,ios::out);

if(outfile1==0){

cout错啦!endl;

exit(1);

}

while(infile1.eof()!=1){

infile1plain[i];

i++;

if(i==8){

plain[9]=\0;

des_ecb_encrypt(plain,encreption,skey);

for(intj=0;j8;j++)

outfile1encreption[j];

//outfile1\0;

i=0;

}

}

for(;i9;i++)

plain[i]=;

plain[9]=\0;

des_ecb_encrypt(plain,encreption,skey);

for(j=0;j8;j++)

outfile1encreption[j];

//outfile1\0;

infile1.close();

outfile1.close();

//coutASDF;

system(PAUSE);

return0;

}

程序执行结果:

例如plaintext.txt存放的明文为:

加密后的密文为:

解密后的明文为:

〔2〕使用附录提供的程序对输入的十六进制数加密〔把输入的字符转化成整数。例如,输入两个字符1F,转化成二进制数000lllll〕,比拟输入和输出。当把输入的数改变一个位时〔如把1F变为1E〕,比拟输出的变化,并说明原因。

程序:

inttransfer(intoriginal

文档评论(0)

liuzhouzhong + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档