- 1、本文档共14页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
java课程设计凯撒加密解密程序
PAGE
JAVA面向对象编程课程设计论文
凯撒加密解密程序
学生姓名: 赵 席 兵
学生学号: 200710802050
院(系): 计算机学院
年级专业: 07信息与计算科学
2010-12-14摘要
凯撒密码作为一种最为古老的对称加密体制,在古罗马的时候都已经很流行,他的基本思想是:通过把字母移动一定的位数来实现加密和解密。例如,如果字母的位数是3,明文字母B就变成了密文的E,依次类推,X将变成A,Y变成B,Z变成C,由此可见,位数就是凯撒密码加密和解密的密钥。
关键字: 凯撒密码 加密 解密
目录
TOC \o 1-3 \h \z \u HYPERLINK \l _Toc280087451 第一节 PAGEREF _Toc280087451 \h 4
HYPERLINK \l _Toc280087452 第二节 PAGEREF _Toc280087452 \h 4
HYPERLINK \l _Toc280087453 第三节 PAGEREF _Toc280087453 \h 5
HYPERLINK \l _Toc280087454 参考文献 PAGEREF _Toc280087454 \h 12
第一节 实例说明
凯撒密码是罗马扩张时期朱利斯?凯撒(Julius Caesar)创造的,用于加密通过信使传递的作战命令。它将字母表中的字母移动一定位置而实现加密。例如如果向右移动2位,则字母A将变为C,字母B将变为D,…,字母X变成Z,字母Y则变为A,字母Z变为B。因此,假如有个明文字符串“Hello”用这种方法加密的话,将变为密文:“Jgnnq”。而如果要解密,则只要将字母向相反方向移动同样位数即可。如密文“Jgnnq”每个字母左移两位变为“Hello”。这里,移动的位数“2”是加密和解密所用的密钥。
第二节 编程思路
首先获取要加密的内容以及密钥,凯撒密码的密钥即字符移动的位数。由于凯撒密码器的移位是针对字符的,因此需要将待加密的内容中每个字符取出,然后针对每个字符分别加以移位。主要步骤如下:
(1) 读取要加密的字符串、密钥
String s=args[0];
int key=Integer.parseInt(args[1]);
分析:作为示例,程序中通过命令行参数传入要加密的字符串。凯撒密码器的密钥比较简单,只是移动的位数,这里不妨通过命令行参数传入。由于移动???位数为整数,因此使用Integer.parseInt( )方法进行了转换。
(2) 取出字符串中每个字符
for(int i=0;is.length( );i++){
char c=s.charAt(i);
分析:这里使用字符串类的 charAt()方法取出每个字符,分别加以移位。
(3) 对每个字符进行移位
c+=key%26;
if(ca) c+=26;
if(cz) c-=26;
分析:由于字母表中共26个字符,因此移位前先将移动的位数(key)和26取模。由于Java中字符和整型可自动转换,因此将字符加上一个正整数即代表在字母表中右移多少位。如果移动的位数是负值,则代表在字母表中左移多少位。
尽管在移动之前已经将移动的位数和26取了模,但通过这种方式实现右移或左移仍可能发生超界。如字母x右移4位应该是字母b,但将字母x增加4后超出26个字母的范围。因此移位后使用两个if语句判断一下,如果向左超界(ca)则增加26;向右超界(cz)则减去26。
此外由于大写字母和小写字母判断是否超界的依据不同,程序中将字符分为大写和小写分别处理。
第三节 代码与分析
源程序:
import java.io.*;
public class Caesar{
public static String path;
public static String estr=;
public static char c;
public static void Encode(String str,int n){
for(int i=0;istr.length();i++){
c=str.charAt(i);
if(c=ac=z)
if(c+n%26=z) estr+=(char)(c+n%26); else estr+=(char)(a+((n-(z-c)-1)%26));
else if(c=Ac=Z)
if(c+n%26=Z) estr+=(char)(c+n%26); else estr+=(cha
您可能关注的文档
- ISPE06终处理选择注射用水.doc
- ISO90012015质量管理体系要求学习word版.doc
- ISSR(inter-sequencerepeat)分子标记的实验原理及操作流程.doc
- ISO90012008版质量手册.doc
- It’sseveno’clock2014年小学教师信息技术应用能力提升全员远程研修.doc
- ISO90012008体系标准.doc
- ISO18000-6B标准中防碰撞算法的改进.doc
- IT公司员工素质能力表.doc
- ITS在区分疑似黄鹌菜上的应用.doc
- IT企业如何进行研发项目管理.doc
- 广东省广州市南武中学2024-2025学年高一上学期综合训练(一)数学试题(含解析).pdf
- 2022-2023学年江西省抚州市金溪县六年级(上)期末数学试卷(含答案).pdf
- 安徽省合肥市第十中学2024-2025学年高一上学期第一次月考生物试题(含答案).pdf
- 2024-2025学年福建省百校联考高三(上)月考数学试卷(10月份)(含答案).pdf
- 2024-2025学年四川省高三(上)联考数学试卷(10月份)(含答案).pdf
- 2024-2025年外研版(2024)七年级上册英语期中试题(含答案).pdf
- 广西南宁市第四十七中学2024-2025学年九年级10月月考物理试卷(含答案).pdf
- 广东省河源市2024-2025学年高二上学期10月月考物理试题(含解析).pdf
- 广东省江门市蓬江区华侨中学2024-2025学年八年级上学期第一次月考物理试题(无答案).pdf
- 2024-2025学年广东省广州市华南师大附中高三(上)月考数学试卷(一)(含答案).pdf
文档评论(0)