javaはアフィニティ暗号の暗号解読を実現します。


本論文の例では、Javaによるアフィニティ暗号暗号解読を実現するための具体的なコードを共有しています。
暗号化:明文を対応する数字に変換します。例えば、「a'-」0、「b'-」1、…、「1'-」26、「2'-」27、…数字をアフィン演算して、取り出した数字を求めて再び文字に変換します。すなわち暗号文=(K 1*明文+K 2)mod 36
暗号文は対応する数字に変換され、アフィンの逆演算を行い、対応する数字を得て、文字の明文に変換されます。復号K 3はK 1の乗算元です。

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);
 }
}
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。