Java實現置換密碼加密解密

Java實現置換密碼加密解密

思路

置換密碼只不過是簡單的換位而已,這裏寫的是一個分組長度爲7的置換密碼因爲所學知識有限,寫的比較麻煩,這裏先簡單介紹一下思路:
1.因爲置換密碼首先要將其進行分組,這裏分組長度爲7,不足的位數補0,可以選取二維數組進行操作,定義二維數組,明文有多少個分組二維數組中就有多少個一維數組,其中一維的長度就是分組長度
2.定義一個一維數組key作爲加密用的祕鑰,一個一維數組trankey作爲解密祕鑰,這裏其中的元素是自己寫的
3.輸入明文,現將其存入擴容好的新建的一維數組中但此時填充位是空字符’\0’,再將其替換爲’0’,存入二維數組中
4.加密,用祕鑰key中的順序對明文進行加密並存入二維數組miwen中
5.解密,用解密祕鑰trankey中的順序對密文解密存入二維數組arr中
6.消去填充的0,算出填充了多少個0,然後用分組長度減去0的個數就是二維數組中最後一個一維數組中非填充位的個數,將其存入一維數組中,在用此一維數組替換最後一個一維數組,這樣就消去了所有的填充的0

代碼

import java.util.Scanner;

public class replacement {


    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("請輸入帶加密的明文:");
        String plaintexts = sc.nextLine();
        int len = plaintexts.length() % 7 == 0 ? plaintexts.length() / 7 : (plaintexts.length() / 7) + 1;//定義二維數組是要用到,主要作用是確定二維數組中一維數組的個數
        char[] plaintext_char = new char[7 * len];//先將明文存入一維數組中,在後面再將其存入二維數組中
        char[][] arr = new char[len][7];//存放明文和解密後的明文的二維數組
        char[][] miwen = new char[len][7];//存放密文的二維數組
        char[] n=new char[7];//在解密過程中用來消掉多餘的填充的0
        int[] key = {6, 3, 0, 4, 1, 5, 2};//加密祕鑰
        int[] transkey = {2, 4, 6, 1, 3, 5, 0};//解密祕鑰

        fill(plaintexts, plaintext_char, len, arr);
        encryption(len, miwen, arr, key);
        System.out.println("加密後的明文是:");
        for (int i = 0; i < len; i++) {
            for (int j = 0; j < miwen[i].length; j++) {
                System.out.print(miwen[i][j]);
            }
        }//輸出密文
        System.out.println(" ");
        System.out.println("按下1解密或按其他任意鍵退出:");
        String a=sc.nextLine();
        if (a.equals("1")){
            decryption(n,len, miwen, arr, transkey,plaintexts);
            for (int i = 0; i < len; i++) {
                for (int j = 0; j < arr[i].length; j++) {
                    System.out.print(arr[i][j]);
                }
            }
        }else {
            System.out.println("退出!");
        }//輸出明文或退出
    }

    public static void fill(String plaintexts, char[] plaintext_char, int len, char[][] arr) {
        for (int i = 0; i < plaintexts.length(); i++) {
            plaintext_char[i] = plaintexts.charAt(i);
        }//將輸入的字符串存入擴充好的一維數組中,此時數組長度已達到標準,但是多出來的填充爲是'\0'
        for (int i = 0; i < plaintext_char.length; i++) {
            if (plaintext_char[i] == '\u0000') {
                plaintext_char[i] = '0';
            }//將字符串數組中的空字符'\0'替換爲0
   	for (int i = 0; i < len; i++) {
            for (int j = i * 7, k = 0; j < 7 * (i + 1) && k < 7; j++, k++) {
                arr[i][k] = plaintext_char[j];
            }
        }//將擴充後的明文存入二維數組中,每七個一個一維數組
    }

    public static void encryption(int len, char[][] miwen, char[][] arr, int[] key) {
        for (int i = 0; i < len; i++) {
            for (int j = 0; j < 7; j++) {
                miwen[i][j] = arr[i][key[j]];
            }
        }
    }//加密方法
    public static void decryption(char[] n,int len, char[][] miwen, char[][] arr, int[] trankey,String plaintexts) {
        for (int i = 0; i < len; i++) {
            for (int j = 0; j < 7; j++) {
                arr[i][j] = miwen[i][trankey[j]];
            }
        }
        for (int i = 0; i <7-(7*len-plaintexts.length()); i++) {
            n[i]=arr[arr.length-1][i];
        }//7-(7*len-plaintexts.length())是二維數組中最後一個一維數組中的非填充位的個數,將非填充位加到n中
        arr[len-1]=n;//用n取代二維數組中最後一個數組,相當於將填充的0消去
    }//解密方法
}

運行結果

請輸入帶加密的明文:
jdlalsdkpa1548796
加密後的明文是:
dajldsl81k5p4a0070906 
按下1解密或按其他任意鍵退出:
1
jdlalsdkpa1548796
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章