2014535郝昊《java程序设计》实验1实验报告
-
实验名称
利用java语言实现凯撒密码,并运行测试。
-
实验内容
用java语言实现凯撒密码,凯撒密码是一种代替的移位密码,它将明文加密的算法是将每一个字母依次向后或向前用其它字母来代替需要加密的明文密码,从而计算出密文密码。
在字母表中,在移位前先将移动的位数(key)和26取模。Java将字符加上一个正整数即代表在字母表中右移多少位。如果移动的位数是负值,则代表在字母表中左移多少位。
-
实验步骤
实验按照以下思路编译和设计即可
-
实验代码及问题解决
import java.io.*; import java.util.Scanner; public class kaisamm { public static void main (String[] args){ System.out.print("请输入密钥: "); Scanner s = new Scanner(System.in); int a= s.nextInt(); C(a); } public static void C(int n ){ try{ char b[]; BufferedReader br2 = new BufferedReader(new InputStreamReader(System.in)); System.out.println("请输入一段明文: "); String str2 = br2.readLine(); b = str2.toCharArray(); System.out.println("密文为: "); int k=n; for (int i=0;i<str2.length();i++){ char ch = (char)((b[i]-'a'+k)%26+'a'); System.out.print(ch); } System.out.println("密钥k = " +k); }catch (IOException e ){ System.out.println(e.getMessage()); } } }
实验结果
尽管在移动之前已经将移动的位数和26取了模,但通过这种方式实现右移或左移仍可能发生超界。如字母x右移4位应该是字母b,但将字母x增加4后超出26个字母的范围。因此移位后使用两个if语句判断一下,如果向左超界(c<'a')则增加26;如果向右超界(c>'z')则减去26。此外,由于大写字母和小写字母判断是否超界的依据不同,程序中将字符分为大写和小写分别处理。所以,对每个字符进行移位,可以通过下面的代码实现:
c+=key%26;
if(c<'a')c+=26;
if(c>'z')c-=26;
- 心得体会
这是第一次做java实验,虽然学习了java有一段时间,但是初次自己构思设计并且编译一个完整的代码最开始还是有点无从下手。但是仔细想想相关的知识凯撒密码已经在现代密码学上接触也了解过了,细心把握住凯撒密码的特点的确对于理清思路会容易许多。
后来自己编译完代码后又去网上搜索相关知识(连接:http://baike.xsoftlab.net/view/109.html),果然发现自己只是简单的实现了凯撒密码,就比如我只能像左移位明文信息,却做不到向右移。而且在移位时候没有注意到即使模26也是有可能会有溢出的情况。我发现了这点并且也弄懂了,也对做出了小改动。总之在java学习放面还是需要很大的提高。