【密码学原理与实践】(四)维吉尼亚密码 符java代码实现

本文介绍了维吉尼亚密码,一种多表代换密码,详细解释了其定义和加密过程。通过举例展示了如何使用密钥进行加密,并提供了具体的Java代码实现。
摘要由CSDN通过智能技术生成

维吉尼亚密码(Vigenere Cipher)

转载请著明出处

无论是移位密码还是代换密码,一旦秘钥被选定,则每个字母对应的数字都被加密变换成对应的唯一数字。我们称这种为单表代换密码,而本篇讲的是一种多表代换密码。

定义

设m是一个正整数,定义P=C=K=(Z26)m,对任意的秘钥K=(k1,k2,k3…km)定义
Ek(x1,x2,x3…xm)=(x1+k1,x3+k2…xm+km)和Dk(y1,y2…yk)=(y1-k1,y2-k2…ym-km)

以上所有的运算都是在Z26上进行。

对应于之前的字母表,则每个密钥K相当于一个长度为m的字符串,称为密钥字。维吉尼亚密码一次加密m个名文字母。

维吉尼亚密码的密钥空间大小为26m,所以即使m的值很小,使用穷尽密钥也需要很长的时间。一般来说,多表代换密码比单表代换密码更为安全一些。

举个栗子

假设m=6,密钥字为CIPHER,其对应于如下的数字串(2,8,15,7,4,17),要加密的明文为:encode and decode,秘钥为mykey
在这里插入图片描述

代码实现
package com.slp.cryptography;

/**
 * @ClassName VigenereCipher
 * @Description 维吉尼亚密码
 * @Author sanglp
 * @Date 2020/11/30 15:55
 * @Version 1.0
 **/
public class VigenereCipher {
   
    static int [] arr = {
   12,24,10,4,24};
    public static 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值