加密与安全_ 凯撒密码

文章目录

  • Pre
  • 概述
  • Code 实现 凯撒密码
  • 字母频率分析攻击
    • Code解密凯撒密码
  • 小结

在这里插入图片描述


Pre

PKI - 02 对称与非对称密钥算法


概述

凯撒密码是一种简单的替换加密技术,也称为移位密码。它是古典密码学中最早的密码之一,得名于古罗马军队领袖凯撒·尤利乌斯(Julius Caesar),据说他曾经使用过这种加密方法。

恺撒密码,也称为恺撒加密或恺撒变换,是一种最古老且最简单的密码之一。它的原理很简单,就是通过将明文中的每个字母按照字母表顺序向后(或向前)移动固定的位置来进行加密。这个固定的位置就是密钥,通常用一个整数来表示,称为偏移量。

例如,当偏移量为3时,明文中的字母A将被加密为D,B被加密为E,以此类推。如果偏移量是负数,则向前移动相应的位置。这种方法相当于在字母表上进行循环移位。

加密过程

  1. 确定偏移量(密钥)。
  2. 对于要加密的明文中的每个字母,按照偏移量进行移位。
  3. 输出密文。

在这里插入图片描述

解密过程

  1. 知道加密时使用的偏移量。
  2. 对于密文中的每个字母,按照偏移量的负值进行移位。
  3. 输出明文。

示例

假设明文为:“HELLO”,偏移量为3。

  • 加密:H + 3 = K,E + 3 = H,L + 3 = O,L + 3 = O,O + 3 = R
  • 密文为:“KHOOR”

安全性

恺撒密码的安全性非常低,因为它只有26种可能的密钥(偏移量),攻击者可以很容易地通过穷举法来破解。因此,它更多地被用于教学和娱乐,而不是实际的安全通信中。

应用

恺撒密码虽然安全性低,但在教学、编程练习以及简单的加密需求中仍有一定的应用价值。


Code 实现 凯撒密码

public class KaiserDemo {public static void main(String[] args) {// 定义原文String input = "Hello Artisan";// 把原文右边移动3位int key = 3;// 凯撒加密String s = encrypt(input, key);System.out.println("加密 " + s);String s1 = decrypt(s, key);System.out.println("明文 " + s1);}/*** 解密** @param s   密文* @param key 密钥* @return*/public static String decrypt(String s, int key) {char[] chars = s.toCharArray();StringBuilder sb = new StringBuilder();for (char aChar : chars) {int b = aChar;// 偏移数据b -= key;char newb = (char) b;sb.append(newb);}return sb.toString();}/*** 加密** @param input 原文* @return*/public static String encrypt(String input, int key) {// 抽取快捷键 ctrl + alt + m// 把字符串变成字节数组char[] chars = input.toCharArray();StringBuilder sb = new StringBuilder();for (char aChar : chars) {int b = aChar;// 往右边移动3位b = b + key;char newb = (char) b;sb.append(newb);}return sb.toString();}
}

在这里插入图片描述


字母频率分析攻击

字母频率分析是一种破译凯撒密码的常见方法。它利用了自然语言中字母的分布特征,即某些字母在文本中出现的频率比其他字母更高。

步骤

  1. 收集密文。
  2. 统计密文中每个字母出现的次数,得到各个字母的频率。
  3. 将频率从高到低排序。
  4. 将排序后的频率与自然语言中字母的频率进行比较,找到最可能对应的字母。
  5. 推断偏移量,并进行解密。

举例

假设有一段密文为:“WKLQJ LV NHHS”。

  1. 统计各个字母出现的次数:

    • W: 1次
    • K: 1次
    • L: 1次
    • Q: 1次
    • J: 1次
    • V: 1次
    • N: 1次
    • H: 2次
    • S: 1次
  2. 按频率排序:H > W, K, L, Q, J, V, N, S

  3. 与自然语言中英文字母的频率进行比较,发现"H"的频率较高,可能对应原文中的"E"。

  4. 推断偏移量为3。

  5. 解密密文:“WKLQJ LV NHHS” -> “THINK IS MEET”

安全性
凯撒密码的安全性很低,因为它只有26种可能的密钥(偏移量),而且容易受到字母频率分析等简单攻击的破解。

Code解密凯撒密码


import java.util.HashMap;
import java.util.Map;/*** @author 小工匠* @version 1.0* @mark: show me the code , change the world*/
public class CaesarCipherBreaker {public static void main(String[] args) {String ciphertext = "Khoor#Duwlvdq";crackCaesarCipher(ciphertext);}// 字母频率分析破解凯撒密码public static void crackCaesarCipher(String ciphertext) {// 统计密文中每个字母出现的次数Map<Character, Integer> frequencies = new HashMap<>();for (char c : ciphertext.toCharArray()) {if (Character.isLetter(c)) {char uppercaseChar = Character.toUpperCase(c);frequencies.put(uppercaseChar, frequencies.getOrDefault(uppercaseChar, 0) + 1);}}// 将统计结果按出现次数从高到低排序frequencies.entrySet().stream().sorted((e1, e2) -> Integer.compare(e2.getValue(), e1.getValue())).forEach(entry -> {char letter = entry.getKey();int frequency = entry.getValue();System.out.println(letter + ": " + frequency);int offset = letter - 'E';if (offset < 0) {offset += 26;}String decryptedText = decryptCaesarCipher(ciphertext, offset);System.out.println("Decrypted Text with offset " + offset + ": " + decryptedText);});}// 凯撒密码解密public static String decryptCaesarCipher(String ciphertext, int offset) {StringBuilder plaintext = new StringBuilder();for (char c : ciphertext.toCharArray()) {if (Character.isLetter(c)) {char baseChar = Character.isLowerCase(c) ? 'a' : 'A';int index = (c - baseChar - offset + 26) % 26;plaintext.append((char) (baseChar + index));} else {plaintext.append(c);}}return plaintext.toString();}
}

我们对每个出现频率的字母都尝试解密文本,并输出每个偏移量对应的解密文本
在这里插入图片描述

发现我们可以读懂,解密成功

在这里插入图片描述


小结

尽管凯撒密码很容易理解和实现,但由于它的简单性,它并不安全,容易受到字母频率分析等攻击。因此,现代加密通常不再使用凯撒密码,而是使用更加复杂的加密算法来保护数据的安全。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/511251.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

『Linux从入门到精通』第 ㉕ 期 - System V 共享内存

文章目录 &#x1f490;专栏导读&#x1f490;文章导读&#x1f427;共享内存原理&#x1f427;共享内存相关函数&#x1f426;key 与 shmid 区别 &#x1f427;代码实例 &#x1f490;专栏导读 &#x1f338;作者简介&#xff1a;花想云 &#xff0c;在读本科生一枚&#xff0…

用Arduino中Wire库写I2C驱动-提高篇(IP2368芯片驱动为例)

之前写了一篇文章“用Arduino中Wire库写I2C驱动-入门篇”&#xff0c;链接地址&#xff1a;用Arduino中Wire库写I2C驱动-入门篇_arduino wire库-CSDN博客对I2C驱动编写做了一个简单的介绍&#xff0c;这一篇里&#xff0c;我们将使用IP2368这个芯片为例&#xff0c;详细的讲解一…

Prometheus结合Grafana监控MySQL,这篇不可不读!

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&am…

枚举——完美立方算法

枚举 基于逐个尝试答案的一种问题求解策略 例如&#xff1a;求小于N的最大素数 找不到一个数学公式&#xff0c;使得根据N就可以计算出这个素数 N-1是素数吗&#xff1f;N-2是素数吗&#xff1f; …… 判断N-i是否是素数的问题 转化成求小于N的全部素数&#xff08;可以用筛法…

【笔记】Android Telephony 漫游SPN显示定制(Roaming Alpha Tag)

一、功能名词简介和显示规则 Alpha Tag&#xff1a;运营商名称标识符&#xff0c;也是用于标识运营商的一个名称。客户需求描述常用名词&#xff0c;对开发而言都是SPN/PLMN功能模块的内容&#xff0c;状态栏左上角的运营商名称显示。 SPN相关文章&#xff1a; 【笔记】SPN和…

从零开始学习Netty - 学习笔记 -Netty入门【协议设计和解析】

2.协议设计和解析 协议 在计算机中&#xff0c;协议是指一组规则和约定&#xff0c;用于在不同的计算机系统之间进行通信和数据交换。计算机协议定义了数据传输的格式、顺序、错误检测和纠正方法&#xff0c;以及参与通信的各个实体的角色和责任。计算机协议可以在各种不同的层…

【C++】STL容器string详解

string详解 一&#xff0c;STL简介1. 版本2. 六大组件 二&#xff0c;string类的使用1. string类的常用构造2. string类容量相关2.1 size和capacity接口2.2 reserve和resize 3. string类对象的访问和遍历&#xff0c;迭代器3.1 运算符重载[]3.2 string迭代器 4. string类对象的…

十九 超级数据查看器 讲解稿 分栏功能

十九 超级数据查看器 讲解稿 分栏功能 点击此处观看视频教程 讲解稿全文: 大家好&#xff0c;这讲介绍一下 &#xff0c;超级数据查看器的分栏功能。 分栏功能设计的初衷是为了让用户同时同地查询两个表格的数据&#xff0c;方便比较&#xff0c;获得更清晰的查询结果 分栏功…

gin gorm学习笔记

代码仓库 https://gitee.com/zhupeng911/go-advanced.git https://gitee.com/zhupeng911/go-project.git 1. gin介绍 Gin 是使用纯 Golang 语言实现的 HTTP Web框架&#xff0c;Gin接口设计简洁&#xff0c;提供类似Martini的API&#xff0c;性能极高&#xff0c;现在被广泛使用…

BUUCTF:[MRCTF2020]ezmisc

题目地址&#xff1a;https://buuoj.cn/challenges#[MRCTF2020]ezmisc 下载附件打开是一张照片&#xff1a; 放到kali中发现crc校验错误&#xff0c;修改照片宽高&#xff1a; 保存即可发现flag flag为&#xff1a; flag{1ts_vEryyyyyy_ez!}

【代码】Python3|无GUI环境中使用Seaborn作图的学习路线及代码(阴影折线图)

我有个需求是需要画图&#xff0c;让GPT帮我生成了一下学习计划。 学习路线依照GPT的来的&#xff0c;使用的Prompt工具是https://github.com/JushBJJ/Mr.-Ranedeer-AI-Tutor。 文章目录 PrerequisiteMain Curriculum1.1 Seaborn介绍Seaborn基础保存图形为文件练习 1.2 单变量数…

适用于 Windows 的 5 款最佳免费数据恢复软件榜单

每个计算机用户都曾经历过数据丢失的情况。很容易错误地删除重要的文件和文件夹&#xff0c;当发生这种情况时&#xff0c;可能会导致不必要的心痛和压力。值得庆幸的是&#xff0c;可以恢复 Windows PC 上丢失的数据。在本文中&#xff0c;我们将分享您可以使用的五种最佳 Win…