信息安全实验报告一(共6页).doc

上传人:飞****2 文档编号:14311855 上传时间:2022-05-03 格式:DOC 页数:6 大小:136.50KB
返回 下载 相关 举报
信息安全实验报告一(共6页).doc_第1页
第1页 / 共6页
信息安全实验报告一(共6页).doc_第2页
第2页 / 共6页
点击查看更多>>
资源描述

《信息安全实验报告一(共6页).doc》由会员分享,可在线阅读,更多相关《信息安全实验报告一(共6页).doc(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上 实验成绩信息安全概论实验报告实验一 古典密码实验专业班级:学号:姓名: 完成时间:2016/ 05/ 09一、 实验目的理解简单加密算法的原理;掌握凯撒密码的原理,完成凯撒密码加解密程序的编写;通过实验,加深对古典密码体制的了解,掌握对字符进行灵活处理的方法。二、 实验内容根据凯撒密码的原理编写程序,对输入的符号串能够根据设置的密钥分别正确实现凯撒加密和解密功能。三、 实验环境和开发工具1. Windows 7 系统2. Eclipse 3. JDK 1.7四、 实验步骤和结果首先获取要加密的内容以及密钥,凯撒密码的密钥即字符移动的位数。由于凯撒密码器的移位是针对字

2、符的,因此需要将待加密的内容中每个字符取出,然后针对每个字符分别加以移位。主要步骤如下:(1) 读取要加密的字符串、密钥。(2) 取出字符串中每个字符。使用字符串类的 charAt()方法取出每个字符,分别加以移位。(3) 对每个字符进行移位。由于字母表中共26个字符,因此移位前先将移动的位数(key)和26取模。由于Java中字符和整型可自动转换,因此将字符加上一个正整数即代表在字母表中右移多少位。如果移动的位数是负值,则代表在字母表中左移多少位。尽管在移动之前已经将移动的位数和26取了模,但通过这种方式实现右移或左移仍可能发生超界。如字母x右移4位应该是字母b,但将字母x增加4后超出26个

3、字母的范围。因此移位后使用两个if语句判断一下,如果向左超界(cz)则减去26。源程序:package Caesar;import java.io.*;import java.util.Scanner;/* * author SiRuYan */public class Caesar / 声明一些全局变量public static String path;public static String estr = ;public static char c;/* * 凯撒密码 加密方法 * * param str * param n */public static void Encode(Stri

4、ng str, int n) for (int i = 0; i = a & c = z)if (c + n % 26 = A & c = Z)if (c + n % 26 = 0 & c = 9) / 对数字进行加密if (c + n % 10 = 9)estr += (char) (c + n % 10);elseestr += (char) (0 + (n - (9 - c) - 1) % 10);elseestr += c;/* * 凯撒密码 解密方法 * param str * param n */public static void Decode(String str, int n

5、) for (int i = 0; i = a & c = a)estr += (char) (c - n % 26);elseestr += (char) (z - (n - (c - a) - 1) % 26);else if (c = A & c = A)estr += (char) (c - n % 26);elseestr += (char) (Z - (n - (c - A) - 1) % 26);else if (c = 0 & c = 0)estr += (char) (c - n % 10);elseestr += (char) (9 - (n - (c - 0) - 1)

6、% 10);elseestr += c;public static void main(String args) String array = ;Scanner in = null;int num;System.out.println(-凯撒密码-);System.out.println(-只支持英文和阿拉伯数字-By SiRuYan-);try System.out.println(1、加密n2、解密n3、暴力破解);System.out.print(请选择:);in = new Scanner(System.in); / 读入选择序号String ed = in.next();if (ed

7、.equals(1) | ed.equals(2) | ed.equals(3) System.out.print(文件路径(*.txt):);path = in.next(); / 读入加密文件路径File file = new File(path); / 声明文件变量,以便读入指定文件路径下的文件内容FileInputStream rdf = new FileInputStream(file); / available()(FileInputStream变量)方法返回的实际可读字节数,也就是总大小byte s = new byterdf.available();/ System.out.p

8、rintln(文件的大小:+rdf.available(); 测试语句int b = rdf.available();while (b = rdf.read(s, 0, b) != -1) / 将文件内容读入字节数组中String content = new String(s, 0, b);array = array + content;rdf.close(); / 关闭输入流if (ed.equals(3) / 3 暴力破解for (int k = 1; k = 10) for (int j = 1; j = 9; j+) Decode(array, k + 26 * j);System.o

9、ut.println(密钥为 + (k + 26 * j)+ 时,结果为 + estr);estr = ;System.out.print(正确的密钥为(整数):);int result = in.nextInt();Decode(array, result); else System.out.print(密钥(整数):);num = in.nextInt();if (ed.equals(1) / 1 加密Encode(array, num);else / 2 解密Decode(array, num);/ 最后重新把加密、解密后的内容,借助文件、缓冲区输入流重新写入文件File f = new

10、 File(path);FileWriter outFile = new FileWriter(f);BufferedWriter bufferOut = new BufferedWriter(outFile);bufferOut.write(estr);bufferOut.newLine();bufferOut.flush();bufferOut.close();System.out.print(原文件是否已成功加密或解密!); elseSystem.out.print(您输入有误。); catch (Exception e) System.out.print(输入错误。);运行结果(注意

11、实验对文件完成加、解密):密钥为: 3 。加密前、后结果如下图: 五、 实验遇到问题及解决方法问题1:程序起初是在eclipse中运行,现在回归到控制台。Java文件中由于包的存在,使一些方法找不到。删除文件首部的引入的package包即可。问题2:实验的对象范围为大小写字母、数字。开始时,解密方法的实现出现了问题,有时候会出现的解密结果,原因是由于相对偏移量的计算出现问题,后来修改后程序运行正确。问题3:实验中忽略了密钥为负的情况。修改偏移量的计算方法,调试程序得出正确结果。实验心得:通过古典密码实验,我对凯撒密码的原理有了一定的认识,加深了对古典密码体制的了解;通过完成凯撒密码加解密程序的编写,巩固了自己的动手编程能力等。凯撒加密体制相对容易实现,另外在网上参考了一些资料,也开阔了自己的眼界,对密钥加密体制有了基本的认知。 专心-专注-专业

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁