Java实现凯撒密码加密,解密,破译

一、 实验目的
通过实际编程掌握kaiser密码的加密、解密与破译,加深对kaiser密码算法的认识。
二、 实验要求:
1、 根据课上所讲的内容,写出加密、解密公式。
2、 把试验内容的三个题目编程求出答案。
3、 把试验报告电子版传到教学网络平台上。

三、 实验环境
运行Windows操作系统的PC机,具有VC++等C语言编译环境
四、 实验内容
1、利用k=7时的kaiser密码加密明文:cryptography
2、利用k=4时的kaiser密码解密密文:QEXLIQEXMG
3、用kaiser密码获得秘文kddkmu,试所有可能解密它。
五、 思路:
1、先将明文字母转换为ASCII码,小写字母97-122,大写字母65-90。再将其减去97或65,即可得到0-25之间的数字
2、根据加密或解密的公式解密。再用类似的方法把0-25之间的数字转化为字母
3、破译时尝试密钥为0-25之间的所有的数字,从结果中挑选出有意义的即为明文。
六源代码
1.加密:package 密码学;

import java.util.Scanner;

public class jiami {

public static void main(String[] args) {
		System.out.println("请输入明文:");
		Scanner zx=new Scanner(System.in);//创建Scanner对象
		String z=zx.nextLine();
		System.out.println("请输入密钥:");
		Scanner zx1=new Scanner(System.i
  • 2
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
密码是一种简单的替换密码,通过将字母按照一个固定的偏移量进行替换来加密消息。要使用穷举法破解密码,可以尝试所有可能的偏移量并解密消息,然后根据解密后的文本判断是否有意义。 在MATLAB中实现密码的穷举法破解可以像这样: ```matlab function plaintext = caesarCrack(ciphertext) alphabet = 'abcdefghijklmnopqrstuvwxyz'; maxShift = 25; % 最大偏移量 for shift = 1:maxShift plaintext = caesarDecrypt(ciphertext, shift); % 判断解密后的文本是否有意义 if isMeaningful(plaintext) % 找到了有意义的解密结果 return; end end % 没有找到有意义的解密结果 plaintext = ''; end function plaintext = caesarDecrypt(ciphertext, shift) alphabet = 'abcdefghijklmnopqrstuvwxyz'; shiftedAlphabet = circshift(alphabet, -shift); plaintext = lower(translate(ciphertext, alphabet, shiftedAlphabet)); end function translatedText = translate(text, fromAlphabet, toAlphabet) [~, idx] = ismember(text, fromAlphabet); idx(idx == 0) = 1; % 处理空格等字符 translatedText = toAlphabet(idx);end function isMeaningful = isMeaningful(text) % 对解密后的文本进行有意义的判断,比如是否包含常见单词等 % 这里略过具体实现步骤 isMeaningful = true; % 假设所有解密结果都是有意义的 end ``` 使用上述代码,你可以将密文作为输入传递给`caesarCrack`函数,它会尝试从1到25的所有偏移量进行解密,并返回第一个有意义的解密结果。请注意,此代码只是一个基本示例,你可能需要根据实际需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值