Java实现仿射密码加密解密

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 = 7;
        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);
    }
}

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
仿射变换加密解密是一种基于数学运算的加密解密方法,可以通过一系列简单的数学运算来加密和解密数据。下面是一个基于Java仿射变换加密解密实现代码: ```java import java.util.Scanner; public class AffineCipher { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.print("请输入要加密的字符串:"); String plainText = scanner.nextLine(); int a = 5; // 仿射变换参数a int b = 8; // 仿射变换参数b // 加密 String cipherText = encrypt(plainText, a, b); System.out.println("加密后的字符串为:" + cipherText); // 解密 String decryptedText = decrypt(cipherText, a, b); System.out.println("解密后的字符串为:" + decryptedText); } /** * 加密方法 * @param plainText 要加密的字符串 * @param a 仿射变换参数a * @param b 仿射变换参数b * @return 加密后的字符串 */ public static String encrypt(String plainText, int a, int b) { StringBuilder stringBuilder = new StringBuilder(); for (int i = 0; i < plainText.length(); i++) { char ch = plainText.charAt(i); if (ch >= 'a' && ch <= 'z') { int x = ch - 'a'; int y = (a * x + b) % 26; char encrypted = (char) ('a' + y); stringBuilder.append(encrypted); } else if (ch >= 'A' && ch <= 'Z') { int x = ch - 'A'; int y = (a * x + b) % 26; char encrypted = (char) ('A' + y); stringBuilder.append(encrypted); } else { stringBuilder.append(ch); } } return stringBuilder.toString(); } /** * 解密方法 * @param cipherText 要解密的字符串 * @param a 仿射变换参数a * @param b 仿射变换参数b * @return 解密后的字符串 */ public static String decrypt(String cipherText, int a, int b) { StringBuilder stringBuilder = new StringBuilder(); // 计算a的逆元a' int aInverse = -1; for (int i = 0; i < 26; i++) { if ((a * i) % 26 == 1) { aInverse = i; break; } } for (int i = 0; i < cipherText.length(); i++) { char ch = cipherText.charAt(i); if (ch >= 'a' && ch <= 'z') { int y = ch - 'a'; int x = (aInverse * (y - b + 26)) % 26; char decrypted = (char) ('a' + x); stringBuilder.append(decrypted); } else if (ch >= 'A' && ch <= 'Z') { int y = ch - 'A'; int x = (aInverse * (y - b + 26)) % 26; char decrypted = (char) ('A' + x); stringBuilder.append(decrypted); } else { stringBuilder.append(ch); } } return stringBuilder.toString(); } } ``` 上面的代码实现了一个简单的仿射变换加密解密方法,可以加密和解密字符串。其中,仿射变换的参数a和b可以自己定义,这里默认设置为a=5、b=8。在实际应用中,可以根据需要调整这两个参数,以获得更好的加密效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值