版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上v 3DES加密算法的实现毕业论文 一、DES加密及解密算法程序源代码:#include <iostream>using namespace std;const static char IP_Table = /IP_Table置换 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,
2、 35, 27, 19, 11, 3, 61, 53, 45, 37, 29, 21, 13, 5, 63, 55, 47, 39, 31, 23, 15, 7; const static char Final_Table = /最终置换 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
3、, 27, 34, 2, 42, 10, 50, 18, 58, 26, 33, 1, 41, 9, 49, 17, 57, 25;const static char S_Box864 = /s_box /* 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,
4、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
5、, 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,
6、 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
7、, 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,
8、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
9、, 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;const static char Rar_Table = /压缩置换 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, 3
10、2;const static char Exp_Table = /扩展置换 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;const static char P_Table=/P置换 16, 7, 20, 21, 29, 12, 28, 17,1, 15, 23, 26,5, 18, 31, 1
11、0,2, 8, 24, 14, 32, 27, 3, 9, 19, 13, 30, 6, 22, 11, 4, 25;const static char KeyRar_Table= 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
12、, 4;/设置全局变量,16轮密钥bool key1648=0;void ByteToBit(bool *Out,char *In,int bits)/字节到位转换函数int i;for(i=0;i<bits;i+)Outi=(Ini/8>>(i%8)&1;void BitToByte(char *Out,bool *In,int bits)/位到字节转换函数int i;for(i=0;i<bits/8;i+)Outi=0;for(i=0;i<bits;i+)Outi/8|=Ini<<(i%8);void Xor(bool *InA,const
13、 bool *InB,int length) /按位异或for(int i=0;i<length;i+)InAi=InBi;void keyfc(char *In) /密钥生成函数int i,j=0,mov,k,m;bool* key0 = new bool56;bool* keyin = new bool64;bool temp;ByteToBit(keyin,In,64); /字节到位的转换for(i=0;i<56;i+) /密钥压缩为56位key0i=keyinKeyRar_Tablei-1;for(i=0;i<16;i+) /16轮密钥产生if(i=0|i=1|i=8
14、|i=15)mov=1;elsemov=2;for(k=0;k<mov;k+) /分左右两块循环左移for(m=0;m<8;m+)temp=key0m*7;for(j=m*7;j<m*7+7;j+)key0j=key0j+1;key0m*7+6=temp;temp=key00;for(m=0;m<27;m+)key0m=key0m+1;key027=temp;temp=key028;for(m=28;m<55;m+)key0m=key0m+1;key055=temp;for(j=0;j<48;j+) /压缩置换并储存 keyij=key0Rar_Tablej
15、-1;delete key0;delete keyin;void DES(char Out8,char In8,bool Type)/加密核心程序,Type=0时加密,反之解密bool* MW = new bool64;bool* tmp = new bool32;bool* PMW = new bool64;bool* kzmw = new bool48;bool* keytem = new bool48;bool* ss = new bool32;int hang,lie,i;ByteToBit(PMW,In,64);for(int j=0;j<64;j+)MWj=PMWIP_Tab
16、lej-1; /初始置换bool *Li=&MW0,*Ri=&MW32;for(i=0;i<48;i+)/右明文扩展置换kzmwi=RiExp_Tablei-1;if(Type=0)/DES加密过程for(int lun=0;lun<16;lun+)for(i=0;i<32;i+)ssi=Rii;for(i=0;i<48;i+)/右明文扩展置换kzmwi=RiExp_Tablei-1;for(i=0;i<48;i+)keytemi=keyluni;Xor(kzmw,keytem,48);/*S盒置换*/for(i=0;i<8;i+)hang=
17、kzmwi*6*2+kzmwi*6+5;lie =kzmwi*6+1*8+kzmwi*6+2*4+kzmwi*6+3*2+kzmwi*6+4;tmpi*4+3=S_Boxi(hang+1)*16+lie%2;tmpi*4+2=(S_Boxi(hang+1)*16+lie/2)%2;tmpi*4+1=(S_Boxi(hang+1)*16+lie/4)%2;tmpi*4=(S_Boxi(hang+1)*16+lie/8)%2;for(i=0;i<32;i+)/P置换Rii=tmpP_Tablei-1;Xor(Ri,Li,32);/异或for(i=0;i<32;i+)/交换左右明文Lii
18、=ssi;for(i=0;i<32;i+)tmpi=Lii;Lii=Rii;Rii=tmpi;for(i=0;i<64;i+)PMWi=MWFinal_Tablei-1;BitToByte(Out,PMW,64);/位到字节的转换else/DES解密过程for(int lun=15;lun>=0;lun-)for(i=0;i<32;i+)ssi=Rii;for(i=0;i<48;i+)/右明文扩展置换kzmwi=RiExp_Tablei-1;for(i=0;i<48;i+)keytemi=keyluni;Xor(kzmw,keytem,48);/*S盒置换*
19、/for(i=0;i<8;i+)hang=kzmwi*6*2+kzmwi*6+5;lie =kzmwi*6+1*8+kzmwi*6+2*4+kzmwi*6+3*2+kzmwi*6+4;tmpi*4+3=S_Boxi(hang+1)*16+lie%2;tmpi*4+2=(S_Boxi(hang+1)*16+lie/2)%2;tmpi*4+1=(S_Boxi(hang+1)*16+lie/4)%2;tmpi*4=(S_Boxi(hang+1)*16+lie/8)%2;for(i=0;i<32;i+)/P置换Rii=tmpP_Tablei-1;Xor(Ri,Li,32);/异或for(i
20、=0;i<32;i+)/交换左右明文Lii=ssi;for(i=0;i<32;i+)tmpi=Lii;Lii=Rii;Rii=tmpi;for(i=0;i<64;i+)PMWi=MWFinal_Tablei-1;BitToByte(Out,PMW,64);/位到字节的转换delete MW;delete tmp;delete PMW;delete kzmw;delete keytem;delete ss;bool RunDes(char *Out, char *In, int datalength, char *Key, bool Type) /加密运行函数,判断输入以及对输
21、入文本8字节分割 if( !( Out && In && Key && (datalength=(datalength+7)&0xfffffff8) ) ) return false;keyfc(Key);for(int i=0,j=datalength%8; i<j; +i,Out+=8,In+=8)DES(Out, In, Type);return true;int main()char* Ki = new char8;char Enter="This is the test of DES!"char* Print = new char200;int len = sizeof(Enter);int i_mf;cout << "请输入密钥(8位):" <<"n"for(i_mf=0;i_mf<8;i_mf+)cin >&
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025江苏南京大学新闻传播学院课题组招聘1人备考题库及答案详解(夺冠系列)
- 2026浙江温州市洞头人才发展有限公司招聘1人备考题库(食堂勤杂员)含答案详解
- 2026四川德阳经开区公办医院考核招聘专业技术人员8人备考题库有完整答案详解
- 2025湖北武汉人才服务发展有限公司招聘政治教师派往武汉市公立职高工作2人备考题库(含答案详解)
- 2025年西安交通大学第一附属医院医学影像科招聘备考题库完整参考答案详解
- 2026云南昭通市绥江县中心敬老院招聘2人备考题库有完整答案详解
- 2025福建厦门市集美区宁宝幼儿园非在编厨房人员招聘1人备考题库及一套完整答案详解
- 2026广西防城港东兴国民村镇银行春季招聘备考题库及参考答案详解一套
- 2025年下半年山东高速云南发展有限公司招聘3人备考题库及答案详解参考
- 2025年广西贺州市富川瑶族自治县自然资源局招聘2人备考题库及答案详解(考点梳理)
- 04S519小型排水构筑物1
- 光纤激光打标机说明书
- 劳动者个人职业健康监护档案
- 《两角和与差的正弦、余弦、正切公式》示范公开课教学PPT课件【高中数学人教版】
- 治理现代化下的高校合同管理
- 境外宗教渗透与云南边疆民族地区意识形态安全研究
- GB/T 28920-2012教学实验用危险固体、液体的使用与保管
- GB/T 26389-2011衡器产品型号编制方法
- GB/T 16588-2009带传动工业用多楔带与带轮PH、PJ、PK、PL和PM型:尺寸
- 人大企业经济学考研真题-802经济学综合历年真题重点
- 建筑抗震鉴定标准课件
评论
0/150
提交评论