SDES用c++和Java实现.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文档。上传文档
查看更多
SDES用c和Java实现

//用c++实现 /* SDES.CPP : Simplified DES C/C++ implementation Write : Zhe(James) Zhu Modify: Wangth */ #include iostream #include string using namespace std; //some consts static int P10MAX= 10; static int P8MAX= 10; static int P4MAX= 4; static int IPMAX= 8; static int IPIMAX= 8; static int EPMAX= 4; // two keys K1 and K2 int K1=0; int K2=0; /*permutation for 10-bit key*/ static int P10[]={3,5,2,7,4,10,1,9,8,6,\0}; /*permutation....*/ static int P8[]={6,3,7,4,8,5,10,9,\0}; static int P4[]={2,4,3,1,\0}; static int IP[]={2,6,3,1,4,8,5,7,\0}; static int IPI[]={4,1,3,5,7,2,8,6,\0}; static int EP[]={4,1,2,3,2,3,4,1,\0}; static int S0[4][4]={ {1,0,3,2}, {3,2,1,0}, {0,2,1,3}, {3,1,3,2}, }; static int S1[4][4]={ {0,1,2,3}, {2,0,1,3}, {3,0,1,0}, {2,1,0,3}, }; int Getlength(int p[]) { int i=0; for(;p[i]!=\0;++i); return i; } int BinaryToDecimal(string binary){ int result=0; for(int i=0;ibinary.length();i++){ result=2*result+(binary[i]-0); } return result; } //print in binary so that we can see the result void printBin(int x, int n) { int mask=1(n-1); while(mask 0){ ((xmask)==0)?printf(0):printf(1); mask =1; } coutendl; } //Permute function int Permute(int inum,int p[],int pmax) { int result=0; int length=Getlength(p); for(int i=0;ilength;++i){ result=1; result|=(inum(pmax-p[i]))1; } return result; } //F function int F(int R, int K) { int t=Permute(R,EP,EPMAX) ^ K; int t0=(t4) 0xf; int t1=t 0xf; t0= S0[((t0 0x8)2) | (t0 1)] [(t01)0x3]; t1= S1[((t1 0x8)2) | (t1 1)] [(t11)0x3]; t= Permute( (t02)|t1, P4,P4MAX); return t; } //fk function int fk(int m, int k){ int l=(m4) 0xf; int r=m 0xf; return ((l ^ F(r,k)) 4)| r; } //switch function int SW(int x){ return ((x 0xf)4) | ((x4) 0xf); } //encryption for 8-bit plaintext int encrypt(int m){ m=Permute(m,IP,IPMAX); m=fk(m,K1); m=SW(m); m=fk(m,K2); m=Permute(m,IPI,IPIMAX); return m; } //decryption for 8-bit ciphertext int decrypt(int m){ m=Permute(m,IP,IPMAX); m=fk(m,K2);

文档评论(0)

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

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

1亿VIP精品文档

相关文档