西电网络安全实验

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

《计算机与网络安全》课程实验

2016年月6月

实验一DES加解密算法的实现

一、实验目的及任务:

掌握DES加密算法的加解密过程。

二、实验环境

VC或TC编程环境;主机操作系统为Windows2000或Windows XP;

三、实验原理

要深入理解对称加密算法,掌握DES加密过程。具备一定的C语言编程技能。

DES( Data DES( Data Encryption Standard)算法,于1977年得到美国政府的正式许可,是一种用56位密钥来加密64位数据的方法。DES算法以被应用于许多需要安全加密的场合。

(一)、密钥生成

1、变换密钥

取得64位的密钥,每个第8位作为奇偶校验位。

2、变换密钥。

(1)、舍弃64位密钥中的奇偶校验位,根据下表(PC-1)进行密钥变换

得到56位的密钥,在变换中,奇偶校验位以被舍弃。

(2)、将变换后的密钥分为两个部分,开始的28位称为C[0],最后的28

位称为D[0]。

(3)生成16个子密钥,初始I=1。

(i)、同时将C[I]、D[I]左移1位或2位,根据I值决定左移的位数。

(ii)、将C[I]D[I]作为一个整体按下表(PC-2)变换,得到48位的K[I] (iii)、从1-2-3-1处循环执行,直到K[16]被计算完成。

(二)、处理64位的数据

1、取得64位的数据,如果数据长度不足64位,应该将其扩展为64位

(例如补零)

2、将64位数据按下表变换(IP)

3、将变换后的数据分为两部分,开始的32位称为L[0],最后的32位称

为R[0]。

4、用16个子密钥加密数据,初始I=1。

(1)、将32位的R[I-1]按下表(E)扩展为48位的E[I-1]

(2)、异或E[I-1]和K[I],即E[I-1] XOR K[I]

(3)、将异或后的结果分为8个6位长的部分,第1位到第6位称为B[1],

第7位到第12位称为B[2],依此类推,第43位到第48位称为B[8]。

(4)、按S表变换所有的B[J],初始J=1。所有在S表的值都被当作4位

长度处理。

(i)将B[J]的第1位和第6位组合为一个2位长度的变量M,M作为在S[J]

中的行号。

(ii)、将B[J]的第2位到第5位组合,作为一个4位长度的变量N,N作为在S[J]中的列号。

(iii)、用S[J][M][N]来取代B[J]。

(iv)、从(i)处循环执行,直到B[8]被替代完成。

(5)、将B[1]到B[8]组合,按下表(P)变换,得到P。

(6)、异或P和L[I-1]结果放在R[I],即R[I]=P XOR L[I-1]。

(7)、L[I]=R[I-1]

(8)、从2-4-1处开始循环执行,直到K[16]被变换完成。

5、、组合变换后的R[16]L[16](注意:R作为开始的32位),按下表(IP-1)

变换得到最后的结果。

四、实验步骤

利用编程语言实现DES加解密算法。

1、编程

2、调试

3、运行结果

4、存盘

五、实验结果

加密:

Key: 0x30 0x30 0x30 0x30......0x30(8个字节)

Data: 0x31 0x31 0x31 0x31......0x31(8个字节)

Mode: Encryption

结果:65 5e a6 28 cf 62 58 5f

解密:

Key: 0x31 0x31......0x31(8个0x31)

Data: 65 5e a6 28 cf 62 58 5f

Mode: Decryption

结果:0x31 0x31......0x31(8个0x31)

六、实验思考题

#include "memory.h"

#include "stdio.h"

#include

using namespace std;

enum {encrypt,decrypt};//ENCRYPT:加密,DECRYPT:解密

void des_run(int out[8],int in[8],bool type=encrypt);

//设置密钥

void des_setkey(const int 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 int *table, int len);

static void trans(bool *out, bool *in);

static void XOR(bool *ina, const bool *inb, int len);//异或

static void rotatel(bool *in, int len, int loop);//循环左移

static void bytetobit1(bool *out,const int *in, int bits);

//位组转换成字节组

static void bittobyte1(int *out, const bool *in, int bits);

static void bytetobit(bool *out,const int *in,int bits);

//置换IP表

const static int 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,2 3,15,7};

//逆置换IP-1表

const static int 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 int 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,3 1,32,1};

//P换位表

const static int 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};

相关文档
最新文档