亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++實現DES加密算法實例解析

2020-01-26 15:25:03
字體:
來源:轉載
供稿:網友

本文所述實例是一個實現DES加密算法的程序代碼,在C++中,DES加密是比較常用的加密算法了,且應用非常廣泛。本CPP類文件可滿足你的DES加密需要,代碼中附帶了豐富的注釋,相信對于大家理解DES可以起到很大的幫助。

具體實現代碼如下:

#include "memory.h"#include "stdio.h"enum {encrypt,decrypt};//ENCRYPT:加密,DECRYPT:解密void des_run(char out[8],char in[8],bool type=encrypt);//設置密鑰void des_setkey(const char key[8]);static void f_func(bool in[32],const bool ki[48]);//f函數static void s_func(bool out[32],const bool in[48]);//s盒代替//變換static void transform(bool *out, bool *in, const char *table, int len);static void xor(bool *ina, const bool *inb, int len);//異或static void rotatel(bool *in, int len, int loop);//循環左移 //字節組轉換成位組static void bytetobit(bool *out,const char *in, int bits);//位組轉換成字節組static void bittobyte(char *out, const bool *in, int bits);//置換IP表const static char ip_table[64]={58,50,42,34,26,18,10,2,60,52,44,36,28,20,12,4,62,54,46,38,30,22,14,6,64,56,48,40,32,24,16,8,57,49,41,33,25,17,9,1,59,51,43,35,27,19,11,3,61,53,45,37,29,21,13,5,63,55,47,39,31,23,15,7};//逆置換IP-1表const static char ipr_table[64]={40,8,48,16,56,24,64,32,39,7,47,15,55,23,63,31,38,6,46,14,54,22,62,30,37,5,45,13,53,21,61,29,36,4,44,12,52,20,60,28,35,3,43,11, 51,19,59,27,34,2,42,10,50,18,58,26,33,1,41,9,49,17,57,25};//E 位選擇表static const char e_table[48]={32,1, 2, 3, 4, 5,4, 5, 6, 7, 8, 9,8, 9, 10,11,12,13,12,13,14,15,16,17,16,17,18,19,20,21,20,21,22,23,24,25,24,25,26,27,28,29,28,29,30,31,32,1};//P換位表const static char p_table[32]={16,7,20,21,29,12,28,17,1,15,23,26,5,18,31,10,2,8,24,14,32,27,3,9,19,13,30,6,22,11,4,25};//pc1選位表const static char pc1_table[56]={   57,49,41,33,25,17,9,1,   58,50,42,34,26,18,10,2,   59,51,43,35,27,19,11,3,   60,52,44,36,63,55,47,39,   31,23,15,7,62,54,46,38,   30,22,14,6,61,53,45,37,   29,21,13,5,28,20,12,4};//pc2選位表const static char pc2_table[48]={   14,17,11,24,1,5,3,28,   15,6,21,10,23,19,12,4,   26,8,16,7,27,20,13,2,   41,52,31,37,47,55,30,40,   51,45,33,48,44,49,39,56,   34,53,46,42,50,36,29,32};//左移位數表const static char loop_table[16]={1,1,2,2,2,2,2,2,1,2,2,2,2,2,2,1};//S盒const static char s_box[8][4][16]={    //s1    14, 4, 13, 1, 2, 15, 11, 8, 3, 10, 6, 12, 5, 9, 0, 7,    0, 15, 7, 4, 14, 2, 13, 1, 10, 6, 12, 11, 9, 5, 3, 8,    4, 1, 14, 8, 13, 6, 2, 11, 15, 12, 9, 7, 3, 10, 5, 0,    15, 12, 8, 2, 4, 9, 1, 7, 5, 11, 3, 14, 10, 0, 6, 13,    //s2    15, 1, 8, 14, 6, 11, 3, 4, 9, 7, 2, 13, 12, 0, 5, 10,  3, 13, 4, 7, 15, 2, 8, 14, 12, 0, 1, 10, 6, 9, 11, 5,    0, 14, 7, 11, 10, 4, 13, 1, 5, 8, 12, 6, 9, 3, 2, 15,    13, 8, 10, 1, 3, 15, 4, 2, 11, 6, 7, 12, 0, 5, 14, 9,    //s3    10, 0, 9, 14, 6, 3, 15, 5, 1, 13, 12, 7, 11, 4, 2, 8,    13, 7, 0, 9, 3, 4, 6, 10, 2, 8, 5, 14, 12, 11, 15, 1,    13, 6, 4, 9, 8, 15, 3, 0, 11, 1, 2, 12, 5, 10, 14, 7,    1, 10, 13, 0, 6, 9, 8, 7, 4, 15, 14, 3, 11, 5, 2, 12,    //s4    7, 13, 14, 3, 0, 6, 9, 10, 1, 2, 8, 5, 11, 12, 4, 15,    13, 8, 11, 5, 6, 15, 0, 3, 4, 7, 2, 12, 1, 10, 14, 9,    10, 6, 9, 0, 12, 11, 7, 13, 15, 1, 3, 14, 5, 2, 8, 4,    3, 15, 0, 6, 10, 1, 13, 8, 9, 4, 5, 11, 12, 7, 2, 14,    //s5    2, 12, 4, 1, 7, 10, 11, 6, 8, 5, 3, 15, 13, 0, 14, 9,    14, 11, 2, 12, 4, 7, 13, 1, 5, 0, 15, 10, 3, 9, 8, 6,    4, 2, 1, 11, 10, 13, 7, 8, 15, 9, 12, 5, 6, 3, 0, 14,    11, 8, 12, 7, 1, 14, 2, 13, 6, 15, 0, 9, 10, 4, 5, 3,    //s6    12, 1, 10, 15, 9, 2, 6, 8, 0, 13, 3, 4, 14, 7, 5, 11,    10, 15, 4, 2, 7, 12, 9, 5, 6, 1, 13, 14, 0, 11, 3, 8,    9, 14, 15, 5, 2, 8, 12, 3, 7, 0, 4, 10, 1, 13, 11, 6,    4, 3, 2, 12, 9, 5, 15, 10, 11, 14, 1, 7, 6, 0, 8, 13,    //s7    4, 11, 2, 14, 15, 0, 8, 13, 3, 12, 9, 7, 5, 10, 6, 1,    13, 0, 11, 7, 4, 9, 1, 10, 14, 3, 5, 12, 2, 15, 8, 6,    1, 4, 11, 13, 12, 3, 7, 14, 10, 15, 6, 8, 0, 5, 9, 2,    6, 11, 13, 8, 1, 4, 10, 7, 9, 5, 0, 15, 14, 2, 3, 12,    //s8    13, 2, 8, 4, 6, 15, 11, 1, 10, 9, 3, 14, 5, 0, 12, 7,    1, 15, 13, 8, 10, 3, 7, 4, 12, 5, 6, 11, 0, 14, 9, 2,    7, 11, 4, 1, 9, 12, 14, 2, 0, 6, 10, 13, 15, 3, 5, 8,    2, 1, 14, 7, 4, 10, 8, 13, 15, 12, 9, 0, 3, 5, 6, 11};static bool subkey[16][48];//16圈子密鑰void des_run(char out[8],char in[8], bool type){    static bool m[64],tmp[32],*li=&m[0], *ri=&m[32];    bytetobit(m,in,64);    transform(m,m,ip_table,64);    if(type==encrypt){       for(int i=0;i<16;i++){           memcpy(tmp,ri,32);           f_func(ri,subkey[i]);           xor(ri,li,32);           memcpy(li,tmp,32);       }    }else{       for(int i=15;i>=0;i--){           memcpy(tmp,li,32);           f_func(li,subkey[i]);           xor(li,ri,32);           memcpy(ri,tmp,32);       }    }    transform(m,m,ipr_table,64);    bittobyte(out,m,64);}void des_setkey(const char key[8]){    static bool k[64], *kl=&k[0], *kr=&k[28];    bytetobit(k,key,64);    transform(k,k,pc1_table,56);    for(int i=0;i<16;i++)    {       rotatel(kl,28,loop_table[i]);       rotatel(kr,28,loop_table[i]);       transform(subkey[i],k,pc2_table,48);    }}void f_func(bool in[32],const bool ki[48]){    static bool mr[48];    transform(mr,in,e_table,48);    xor(mr,ki,48);    s_func(in,mr);    transform(in,in,p_table,32);}void s_func(bool out[32],const bool in[48]){    for(char i=0,j,k;i<8;i++,in+=6,out+=4)    {       j=(in[0]<<1)+in[5];       k=(in[1]<<3)+(in[2]<<2)+(in[3]<<1)+in[4];       bytetobit(out,&s_box[i][j][k],4);    }}void transform(bool *out,bool *in,const char *table,int len){    static bool tmp[256];    for(int i=0;i<len;i++)       tmp[i]=in[table[i]-1];    memcpy(out,tmp,len);}void xor(bool *ina,const bool *inb,int len){    for(int i=0;i<len;i++)       ina[i]^=inb[i];}void rotatel(bool *in,int len,int loop){    static bool tmp[256];    memcpy(tmp,in,loop);    memcpy(in,in+loop,len-loop);    memcpy(in+len-loop,tmp,loop);}void bytetobit(bool *out,const char *in,int bits){    for(int i=0;i<bits;i++)       out[i]=(in[i/8]>>(i%8)) &1;}void bittobyte(char *out,const bool *in,int bits){    memset(out,0,(bits+7)/8);    for(int i=0;i<bits;i++)       out[i/8]|=in[i]<<(i%8);}void main(){    char key[8]={'p','r','o','g','r','a','m'},str[8];    puts("*****************DES***********************");    printf("/n");    printf("/n");    puts("please input your words");    gets(str);    printf("/n");    puts("****************************************");    des_setkey(key);    des_run(str,str,encrypt);    puts("after encrypting:");    puts(str);    printf("/n");    puts("****************************************");    puts("after decrypting:");    des_run(str,str,decrypt);    puts(str);    printf("/n");    puts("****************************************");    printf("/n");}

感興趣的朋友可以測試運行一下本文實例,相信能夠對大家的C++程序開發起到一定的幫助作用。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩免费观看中文| 欧美激情视频一区| 91精品国产色综合| 亚洲国产欧美一区二区丝袜黑人| 欧美亚洲视频一区二区| 精品国产精品三级精品av网址| 色777狠狠综合秋免鲁丝| 午夜精品久久久久久久99热| 日韩黄色高清视频| 欧美精品18videos性欧美| 欧美性猛交xxx| 久久久久久久久久久国产| 亚洲一区二区三区四区视频| 日韩av一区在线| 性夜试看影院91社区| 国产精品久久久久久久久久久久久久| 亚洲人线精品午夜| 亚洲石原莉奈一区二区在线观看| 亚洲欧美三级伦理| 久久影视电视剧免费网站| 91精品国产综合久久香蕉| 亚洲国产精品久久久久秋霞蜜臀| 欧美激情亚洲视频| 成人福利视频在线观看| 欧美成人黑人xx视频免费观看| xxxxx成人.com| 成人春色激情网| 国产视频久久久久| 91精品国产乱码久久久久久久久| 欧美成人中文字幕| 欧美日韩亚洲一区二| 日韩成人小视频| 日韩欧美一区二区在线| 久久久久国产精品免费网站| 国产区亚洲区欧美区| 色777狠狠综合秋免鲁丝| 亚洲精品suv精品一区二区| 亚洲美女av在线播放| 精品国偷自产在线视频| 91在线高清视频| 日韩精品极品视频免费观看| 欧美高清视频在线播放| 92裸体在线视频网站| 亚洲黄色免费三级| 国产日韩在线亚洲字幕中文| 久久99久久久久久久噜噜| 韩国精品久久久999| 国产精品国内视频| 亚洲成人av片在线观看| 亚洲综合中文字幕在线| 精品国产欧美成人夜夜嗨| 亚洲深夜福利在线| 精品成人在线视频| 久久影院资源网| 国产精品香蕉av| 精品亚洲一区二区三区| 国内精品美女av在线播放| 欧美成人精品在线播放| 亚洲欧美中文日韩在线v日本| 国产精品美女免费看| 成人在线视频网| 欧洲成人性视频| 久久久久五月天| 日本欧美中文字幕| 久久国产色av| 精品视频—区二区三区免费| 国产亚洲精品久久久久久777| 国产精品毛片a∨一区二区三区|国| 国产乱人伦真实精品视频| 亚洲第一免费网站| 久久伊人精品天天| 亚洲欧美一区二区激情| 亚洲精品国产综合区久久久久久久| 欧美日本啪啪无遮挡网站| 高潮白浆女日韩av免费看| 日韩av电影免费观看高清| 久久九九全国免费精品观看| 黑人巨大精品欧美一区二区三区| 色狠狠久久aa北条麻妃| 国产亚洲视频在线观看| 97视频在线观看免费高清完整版在线观看| 国产成人精品av| 日韩av在线资源| 97成人在线视频| 亚洲美女av在线| 91成人在线观看国产| 国产免费亚洲高清| 中文字幕日韩免费视频| 欧美日韩不卡合集视频| 亚洲国产日韩欧美在线图片| 日韩av中文字幕在线免费观看| 一二美女精品欧洲| 成人h视频在线观看播放| 亚洲成人激情在线观看| 国产精品扒开腿做爽爽爽男男| 国产精品扒开腿做爽爽爽视频| 午夜精品久久久久久久99黑人| 日韩国产欧美精品在线| 国产日韩欧美日韩大片| 日本高清视频精品| 日韩三级成人av网| 国产精品一区=区| 欧美亚州一区二区三区| 国产精品久久久久久久久久ktv| 精品国产一区二区三区久久狼5月| 午夜精品久久久久久久99热浪潮| 欧美日韩国内自拍| 日日骚久久av| 久久国产精品偷| 国产91色在线播放| 国产日产亚洲精品| 最新日韩中文字幕| 亚洲成人亚洲激情| 91av成人在线| 国产成人高清激情视频在线观看| 亚洲香蕉成人av网站在线观看| 中文字幕精品影院| 日韩电影中文字幕一区| 91天堂在线视频| 国产精品成人在线| 久久久久久久爱| 成人久久一区二区| 亚洲精品国产欧美| 欧美性xxxxx| 久久精品国产亚洲| 亚洲级视频在线观看免费1级| 午夜精品福利在线观看| 日韩高清不卡av| 国产精品偷伦一区二区| 久久久久久这里只有精品| 亚洲美女av在线播放| 国产99久久久欧美黑人| 欧美性做爰毛片| 久久久精品久久久久| 美女黄色丝袜一区| 精品偷拍一区二区三区在线看| 中文字幕v亚洲ⅴv天堂| 国产精品美女免费视频| 亚洲级视频在线观看免费1级| 日韩欧美一区二区三区久久| 国产裸体写真av一区二区| 色爱av美腿丝袜综合粉嫩av| 亚洲午夜精品久久久久久久久久久久| 51久久精品夜色国产麻豆| 日韩精品在线免费播放| 亚洲视频在线观看| 亚洲美女在线视频| 国产精品久久久久久久久久久新郎| 91在线无精精品一区二区| 狠狠做深爱婷婷久久综合一区| 欧美福利视频在线| 亚洲精品美女久久久久| 亚洲国产另类 国产精品国产免费| 欧美精品videos另类日本| 欧美精品videosex极品1| 亚洲欧美日韩国产精品| 国产日韩在线视频| 亚洲精品一区中文字幕乱码| 亚洲精品第一国产综合精品| 国产欧美一区二区三区在线| 亚洲精品视频播放| 亚洲最大av网| 亚洲第一区第一页| 成人黄色在线播放|