标准字头密码体制c语言,关于Playfair密码体制
第一步,你需要一个密钥,当然是英文的了,一句话或者几个单词,比如HOW ARE YOU。然后把这组密钥里重复的字母去掉,只留第一次出现的,自然,空格也要去掉,于是变成HOWAREYU。把密钥记下来,或者传给你要发送密码过去的人,然后开始下一步。
第二步,做一5*5矩阵,把密钥每5个字母断开,作为一行,直到密钥每个字母都排在矩阵中,然后紧接着密钥最后一个字母,以“除去密钥中的字母的字母表”(是残缺的字母表,额。。真不好表达)顺序将其它字母填入矩阵(除了Q以外,因为PLAYFAIR矩阵是5*5的仅有25个位置,而Q最不常用,另有方法是I和J占同一个位置,这要依情况而定灵活处理。)于是我们得到:
HOWAREYUBCDFGIJKLMNPSTVXZ长呼一口气,终于完成了准备工作。
第三步:写下你要传递的话,即明文。这里以I AM BRILLS为例
首先要分组,把空格去掉然后每两个字母分为一组
IA MB RI LL S
这时我们发现了一个问题,有同样的字母被分到了一组,而且有一组只有一个字母,先说第一种情况:若某组中出现了同样字母,在这两个字母间加字母X,然后重新分组。第二种情况,若发现第一种情况调整后最后一组仅有一个字母,则在其后加字母X。
按照这个规则,我们得到了
IA MB RI LX LS
第四步:开始加密工作。对照刚才分组好的明文,在矩阵中找出相应的字母对的位置,然后按照下面的规则在矩阵中寻找明文字母对对应的密码字母对:
1.若明文对在矩阵中是对角关系,那么以这两字母连线为对角线作矩形,另一对角线两端的字母就是密码,如果明文顺序是左下到右上,那么密码顺序就是右下到左上(有时跟写X的方法很像),以此类推。比如:MB->NU
2.若明文对在矩阵中是同行关系,那么将这对字母均向右移一格,若有字母在右边界,则移动到同行左边首字母,例如HR->OH
3.若明文对在矩阵中是同列关系,那么将这对字母均向下移一格,遇到边界时方法与2中的类似。
*这些规则是约定好的,当然,如果你与对方也可以有新的约定。
依照规则1、2、3,将明文转换为密码:NB UN AJ NT KT
庆祝一下,终于完成了!!
由于PLAYFAIR密码是对称密码,所以解密就是加密的逆过程,把规则1、2、3逆转过来就是解密方法啦。
标准字头密码体制c语言,关于Playfair密码体制相关推荐
- 标准字头密码体制c语言,现代密码学知识点整理:.doc
PAGE \* MERGEFORMAT PAGE \* MERGEFORMAT 12 基本概念 密钥体制组成部分: 明文空间,密文空间,密钥空间,加密算法,解密算法 2.一个好密钥体制至少应满足的两个 ...
- 标准字头密码体制c语言,密码 实验1 打印
北京建筑工程学院 理学院 实验报告 课程名称 现代密码学实验名称 单表古典密码体制信息加密技术 实验地点 基C-423 日期 2015-5-4 姓名 黄成运 班级 信121 学号 2108191211 ...
- 密码学——几种典型的古典密码体制(Caesar体制、Playfair体制、Vigenere体制、Beaufort体制以及Hill体制)
本篇文章将对几种典型的单表.多表古典密码体制进行总结,其中包括单表密码体制的Caesar体制.Playfair体制和多表密码体制的Vigenere体制.Beaufort体制以及Hill体制.并展示部分 ...
- 由ANSI标准定义的C语言关键字,C语言32个关键字详解
C语言中32个关键字详解 由ANSI标准定义的C语言关键字共32个: auto double int struct break else long switch case enum register ...
- 质量管理体系标准杂谈--管理的语言(原创)
质量管理体系标准杂谈--管理的语言 ISO 是国际标准化组织(INTERNATIONAL ORGANIZATION OF STANDARDIZATION)的缩写.该组织成立于1946年.ISO9000 ...
- C语言实现移位密码体制
问题描述:输入密钥K的值,加密算法:e(x)=x+k(mod 26).即当前明文字母顺序(如A为1)加上K值之后对应的字母即为密文.解密算法:d(y)=y-k(mod 26).与加密相反,解密是当前密 ...
- C语言实现仿射密码体制
算法思想: 1.通过用户输入的加密函数的斜率和截距(a与b),可以利用a计算出a的逆源.在输入a之后,要判断a与26是否互素(即a值与26的最大公约数为1),代码中采用辗转相除法,如果不符合要求,请提 ...
- C语言实现S-DES密码体制
问题描述:根据输入的10bit主密钥,将输入的8bit明文(密文)加密(解密)成8bit的密文(明文). 例:输入:明文0100 0011 主密钥:10100 00 ...
- c语言如何设置c99标准,新的C语言: C99标准介绍
新的C语言: C99标准介绍 Randy Meyers 此篇文章摘取与即将登载于<Dr.Dobb's 软件研发>>第二期(2003年9月)的<新的C语言,C99标准介绍> ...
最新文章
- 2022-2028年中国PVC糊树脂行业市场深度分析及市场规模预测报告
- Elasticsearch索引(company)_Centos下CURL增删改
- Cookie与Web Storage的区别
- 简单分析KafKa工作原理
- java文本框双击可编辑_java swing 文本域双击变为可编辑
- Spring Cloud 入门 之 Config 篇(六)
- c语言实验一的错误,C语言实验(三)
- kali 安装volatility_电子取证技术之实战Volatility工具
- xml引入约束示例(xsd文件)
- DevExpress v18.1新版亮点——ASP.NET Bootstrap篇(二)
- 6.输入四个数,找出最大值方法二
- Kata: 从随机的三字符列表组中恢复秘密字符串
- python:拼接多个csv文件
- Arduino Uno+步进电机28BYJ-48+ULN2003 实现简单的正反转demo
- c51单片机外部中断汇编语言,51单片机汇编语言外部中断笔记
- 友善串口工具 电子秤_Serial Port Utility(友善串口调试助手)
- 20P60 PR模板预设10 VHS专业预设包制作旧镜头复古磁带效果含背景音乐
- win7升级win10方法
- Deep Learning for Weakly-Supervised Object Detection and Object Localization: A Survey
- 2021年焊工作业熔化焊接与热切割考试题库与解析
热门文章
- XGBoost参数调优完全指南(附Python代码)
- 电子数字计算机的应用,你了解电子数字计算机的发展吗?人类是如何应用计算机技术的?...
- 对WEB应用的粗浅理解
- 云游戏学习与实践(一)——云游戏概述
- 【操作系统】I/O系统
- hadoop自定义机架实现-08
- ML之interpret:基于titanic泰坦尼克是否获救二分类预测数据集利用interpret实现EBC模型可解释性之全局解释/局部解释案例
- python错误找回_python字典键错误无法恢复
- 微信快捷回复怎么设置?
- selenium、you-get下载B站视频、监控播放量和弹幕