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