标准字头密码体制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逆转过来就是解密方法啦。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值