密码学实验报告

《 — 现代密码学—》 实 验 指 导 书

适用专业: 计算机科学与技术

江苏科技大学计算机科学学院

2011年 11 月

实验一 古典密码

实验学时:2学时 实验类型:验证 实验要求:必修 一、实验目的

编程实现古典密码的加解密方法。 二、实验内容

(1)移位密码的加密和解密函数。 (2)仿射密码的加密和解密函数。 (3)维吉尼亚密码的加密和解密函数。 三、实验原理、方法和手段 (1)移位密码

对于明文字符x,加密密钥k,加密方法为 y?x?k,k?1,2, 解密方法为 x?y?k,k?1,2,(2)仿射密码

对于明文字符x,加密密钥(a,b),加密方法为 y?ax?b,gcd(a,26)?1,b?1,2, 解密方法为 x?a?1(y?b)

(3)维吉尼亚密码

选取密钥字Key,将明文按照密钥字长度分组,将明文与密钥字对应字符相加并对26求余,即为密文字符。

,25

,25

,25

yi?xi?ki

解密过程为

xi?yi?ki 四、实验组织运行要求

本实验采用集中授课形式,每个同学独立完成上述实验要求。 五、实验条件

每人一台计算机独立完成实验,有如下条件: (1)硬件:微机;

(2)软件:VC++6.0、VC++.Net 2005。 六、实验步骤

(1)将各函数编写完成;

(2)在主函数中调用各函数,实现加密和解密。 七、实验报告

实验报告主要包括实验目的、实验内容、实验原理、源程序及结果。 移位密码加密: #include #define n 3 //移位位数

void change(char string[]) { int i;

for(i=0;string[i]!='\\0';i++) {

if(string[i]>='a'&&string[i]<='z')

string[i]=(string[i]+n>='z'?string[i]+n-26:string[i]+n); } }

void main() {

char str[100];

printf(\请输入一段明文\ gets(str); change(str);

printf(\密文为:\\n\ puts(str); }

移位密码解密: #include #define n 3 //移位位数 void change(char string[]) { int i;

for(i=0;string[i]!='\\0';i++) {

if(string[i]>='a'&&string[i]<='z')

string[i]=(string[i]+n<'a'?string[i]-n+26:string[i]-n); } }

void main() {

char str[100];

printf(\请输入一段密文\ gets(str); change(str);

printf(\明文为:\\n\ puts(str); }

仿射密码加密: #include

void fun( char a[],int x,int y) { int i;

for(i=0;a[i]!='\\0';i++) {

a[i]=(x*(a[i]-97)+y)&+97; } } main() {

char string[100];

int x,y;

printf(\输入\gets(string); printf(\请输入密钥\scanf(\printf(\明文:%s\\n\fun(string,x,y);

联系客服:779662525#qq.com(#替换为@) 苏ICP备20003344号-4