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