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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
SpringBoot中AOP的動態(tài)匹配和靜態(tài)匹配詳解
這篇文章主要介紹了SpringBoot中AOP的動態(tài)匹配和靜態(tài)匹配詳解,在創(chuàng)建代理的時候對目標類的每個連接點使用靜態(tài)切點檢查,如果僅通過靜態(tài)切點檢查就可以知道連接點是不匹配的,則在運行時就不再進行動態(tài)檢查了,需要的朋友可以參考下2023-09-09
java模擬ajax訪問另一個項目的controller代碼實例
今天小編就為大家分享一篇關于java模擬ajax訪問另一個項目的controller代碼實例,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03
Java通過反射機制將對象封裝成JSON和JsonArray格式
這篇文章主要介紹了Java通過反射機制將對象封裝成JSON和JsonArray格式,JAVA反射機制是在運行狀態(tài)中,對于任意一個實體類,都能夠知道這個類的所有屬性和方法,需要的朋友可以參考下2023-10-10
Java?MethodHandles介紹與反射對比區(qū)別詳解
這篇文章主要為大家介紹了Java?MethodHandles介紹與反射對比區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11
Java循環(huán)創(chuàng)建對象內存溢出的解決方法
在Java中,如果在循環(huán)中不當地創(chuàng)建大量對象而不及時釋放內存,很容易導致內存溢出(OutOfMemoryError),所以本文給大家介紹了Java循環(huán)創(chuàng)建對象內存溢出的解決方法,需要的朋友可以參考下2025-01-01

