时间:2021-05-19
本文实例为大家分享了java实现仿射密码加密解密的具体代码,供大家参考,具体内容如下
加密:将明文转化为对应的数字,如 ‘a'-> 0, ‘b'->1,…,'1'->26,'2'->27,…然后将数字进行仿射运算,求取出来的数字再转化为字符。即 密文=(K1*明文+K2)mod36
解密:密文转化为对应数字,然后进行仿射的逆运算,得到对应数字,然后将其转化为字符明文。解密 K3是K1的乘法逆元
import java.util.Scanner;public class Affine{ public static void main(String[] args) { char[] form = {'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', '0' , '1', '2', '3', '4', '5', '6', '7', '8', '9'}; Scanner sc = new Scanner(System.in); System.out.println("请输入待加密的明文:"); String MingWen = sc.nextLine(); MingWen=MingWen.toUpperCase();//将输入的明文全部大写 final int K1 = 103; final int K2 = 103; final int K3 = 31; int [] cipherNum=new int[MingWen.length()];//用来存储数字化的密文 encryption(MingWen,form,K1,K2,cipherNum); decryption(form,MingWen,K2,K3,cipherNum); } public static void encryption(String MingWen,char[] form,int K1,int K2,int[] cipherNum){ //第一步:将明文存入数组 char[] pla=new char[MingWen.length()]; for (int i = 0; i <MingWen.length() ; i++) { pla[i]=MingWen.charAt(i); }//已将明文存入字符数组pla中 //第二步:通过脚标找到明文中每个字符对应的数,参与加密运算 int[] MingWenNumber=new int[pla.length]; for (int i = 0; i <pla.length ; i++) { for (int j = 0; j <form.length ; j++) { if (form[j]==pla[i]) { MingWenNumber[i] = j; } } } //通过脚标将明文全部转化为数字 char[] cipher = new char[MingWen.length()];//cipher密码数组 用来存储密文 for (int i = 0; i <MingWen.length() ; i++) { int a= Math.floorMod((K1*MingWenNumber[i]+K2),36); cipherNum[i]=a; cipher[i]=form[a]; //计算密文并存入数组中 } System.out.println("加密结果是:"); System.out.println(cipher); } public static void decryption(char[] form,String Mingwen,int K2,int K3,int[] cipherNum){ char[] JieMI=new char[Mingwen.length()]; for (int i =0;i<Mingwen.length();i++){ JieMI[i]=form[Math.floorMod(K3*(cipherNum[i]-K2),36)]; } System.out.println("解密结果是:"); System.out.println(JieMI); }}以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
仿射密码思路:1、加解密公式:2、构造对应字典:3、代码实现构造字典,建立映射关系:#构造字典,'A'-->0...defchar_2_num(x):list_
在本教程中,我们将看到如何使用JDK中的Java密码体系结构(JCA)来实现AES加密和解密。对称密钥块密码在数据加密中起重要作用。这意味着同一密钥可用于加密和
本文实例讲述了java使用Hex编码解码实现Aes加密解密功能。分享给大家供大家参考,具体如下:这里的Aes加密解密方法使用Hex进行了编码解码packagec
用户需要输入解密密码才能访问已加密的虚拟机。没有解密密码,就无法访问加密虚拟机的VMDK文件。VMwareWorkstation加密位于物理计算硬件的启动密码之
本文实例为大家分享了Java实现置换密码加密解密,供大家参考,具体内容如下思路置换密码只不过是简单的换位而已,这里写的是一个分组长度为7的置换密码因为所学知识有