DES的数据加密实现ppt.pptVIP

  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的数据加密实现ppt.ppt

DES的数据加密实现 目录 DES背景 DES是由美国IBM公司于20世纪70年代中期的密码算法发展而来的,在1977年1月15日,美国国家标准局正式公布实施,并得到了ISO的认可。在过去近20年的时间里,DES被广泛应用于美国联邦和各种商业信息的安全保密工作中,经受信了各种密码分析和攻击,体现出了令人满意的字全性。 DES工作模式 DES算法是这样工作的:如Mode为加密,则用Key 去把数据Data进行加密, 生成Data的密码形式(64位)作为DES的输出结果;如Mode为解密,则用Key去把密码形式的数据Data解密,还原为Data的明码形式(64位)作为DES的输出结果。在通信网络的两端,双方约定一致的Key,在通信的源点用Key对核心数据进行DES加密,然后以密码形式在公共通信网(如电话网)中传输到通信网络的终点,数据到达目的地后,用同样的Key对密码数据进行解密,便再现了明码形式的核心数据。 DES加密原理 DES算法是对称加密算法,加密时需要有两个输入:明文和密钥。明文的长度为64位,密钥的长度为64位(64密钥中只有56位是有效的,其他为校验位)。 DES详细算法示意图 每轮变换的详细过程 S盒示意图 密钥产生示意图 DES加密实现过程 /* DES类声明 */ class DES { public: DES();/*构造函数*/ void encrypt(bool flag = true);/*加解密函数*/ private: string plaintextFilePath_;/*明文文件路径*/ string ciphertextFilePath_;/*密文文件路径*/ string keyFilename_;/*密钥文件路径*/ string plaintext_;/*明文存储*/ string ciphertext_;/*密文存储*/ string key_;/*密钥存储*/ vectorvectorint subkey_;/*子密钥存储*/ void getsubkey_();/*计算子密钥*/ void setPlaintextFilePath_();/*设置明文路径*/ void setCiphertextFilePath_();/*设置密文路径*/ void setKeyFilePath_();/*设置密钥路径*/ string readData_(string filename);/*读取文件*/ void saveData_(string filename,string data);/*保存文件*/ vectorint string2bit_(string str); /*string类型转为ASCII二进制数*/ string bit2string_(vectorint v);/*ASCII二进制数转为string类型*/ vectorint int2bit_(vectorint vecInt);/*整形数0-15化为二进制*/ vectorint vecXor_(vectorint vL, vectorint vR);/*向量异或*/ vectorint leftIterMove_(vectorint movVec,int loopStep);/*数据左移loopStep位*/ vectorint vecReplace_(vectorint v,const unsigned int vArray[]);/*向量数据按vArray中数据重排序*/ vectorint vecMerge_(vectorint vL, vectorint vR);/*合并两个向量*/ vectorint f_(vectorint vecR, vectorint vecKey);/*f函数*/ vectorint S_(vectorint vecRKey);/*S盒函数*/ 变换矩阵 */ static const unsigned int PC_1_[56]; static const unsigned int PC_2_[48]; static const unsigned int LOOP_[16]; static const unsigned int IP_[64]; static const unsigned int IPR_[64]; static const unsigned int SBOX_[8][4][16]; static const unsigned int E_[48]; static const unsigned int P_[32]; 程序运行结果 Thank you * * DES背景

文档评论(0)

此项为空 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档