中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中怎么實現一個波雷費密碼算法

發布時間:2021-06-25 16:47:45 來源:億速云 閱讀:224 作者:Leah 欄目:編程語言

java中怎么實現一個波雷費密碼算法,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

一、算法描述

波雷費密碼是一種對稱式密碼,是首種雙字母取代的加密法。

下面描述算法步驟:

1、從1號二維碼M05,提取明文信息和密文,M05格式:<xxx…xxx|yyy…yyy>,其中明文xxx…xxx,密鑰部分信息為yyy…yyy中的提取所有英文字母信息。

2、將提取的英文字母作密匙。除去重復出現的字母。將密匙的字母逐個逐個加入5×5的矩陣內,剩下的空間將未加入的英文字母依A-Z的順序加入。(將Q去除)

3、將要加密的訊息分成兩個一組。若組內的字母相同,將X加到該組的第一個字母后,重新分組。若剩下一個字,也加入X字。

4、在每組中,找出兩個字母在矩陣中的地方。若兩個字母不同行也不同列,在矩陣中找出另外兩個字母,使這四個字母成為一個長方形的四個角。   若兩個字母同行,取這兩個字母右方的字母(若字母在最右方則取最左方的字母)。   若兩個字母同列,取這兩個字母下方的字母(若字母在最下方則取最上方的字母)。

5、新找到的兩個字母就是原本的兩個字母加密的結果。

6、取密文前3個字符與后三個字符(大寫字母)作為對應6位的紅外報警開啟碼。

二、算法過程示例

例:二維碼內容為:<hidethegold|play5fair9example>。

1.明文信息hidethegold和密匙playfairexample  

2.根據密鑰形成5*5的矩陣。

P L A Y F I R E X M B C D G H J K N O S T U V W Z

3.明文處理為:“HI DE TH EG OL DX”

4.就會得到密文:“BM ND ZB XD KY GE”,

5.取密文前6個字符(大寫字母)對應6位的報警碼:0X42,0X4D,0X4E,0X44, 0X5A, 0X42

三、具體代碼如下:

import sun.applet.Main;public class blf {  public static void main(String[] args) {    String s = "<hidethegold|play5fair9example>";    get_blf(s);  }  public static void get_blf(String ssss){    String eng = "ABCDEFGHIJKLMNOPRSTUVWXYZ";    String beg = ssss.replaceAll("[<>0-9]", "");    String []ss = beg.split("\\|");    String mw = ss[0].toUpperCase();    String str = ss[1].toUpperCase();    str = removeMethod(str);    System.out.println(str);    int bs = str.length() / 5;    int ys = str.length() % 5;    System.out.println(ys);    System.out.println(bs);    char[][] arr = new char[5][5];    for (int i = 0; i < bs; i++) {      arr[i] = str.subSequence(i * 5, (i+1) * 5).toString().toCharArray();    }    String yss = str.subSequence(bs*5, (bs*5+ys)).toString();    String other = eng.replaceAll("["+ str +"]", "");    System.out.println("other=" + other);    arr[bs] = (yss + other.subSequence(0,(5-ys) )).toString().toCharArray();    int bs1 = bs + 1;  //把余數補全    int oth = 25 - (bs1 * 5);//剩下的長度    other = other.subSequence((5 - ys), (oth + 5 - ys)).toString();    System.out.println("other=" + other);    int c = 5 - bs1;    System.out.println("c=" + c);    for (int i = 0; i < c; i++) {      System.out.println("bs1=" + bs1);      arr[bs1++] = other.subSequence(i * 5, (i+1) * 5).toString().toCharArray();    }    for (int i = 0; i < arr.length; i++) {      for (int j = 0; j < arr[i].length; j++) {        System.out.print(arr[i][j] + "\t");      }      System.out.println();    }// arr[0] = one.toCharArray();// arr[1] = two.toCharArray();// arr[2] = three.toCharArray();// arr[3] = four.toCharArray();// arr[4] = five.toCharArray();    String s= "";    for (int i = 0; i < mw.length()-1; i = i + 2) {      if(mw.charAt(i) != mw.charAt(i+1)){        s += "" + mw.charAt(i) + mw.charAt(i + 1) + " ";      }      if(i == (mw.length() - 3)){        s += mw.charAt(i+2) + "X";      }    }    System.out.println("s="+s);    String []s1 = s.split(" ");    String s2 = "";    for (int i = 0; i < s1.length; i++) {      s2 += resolve(arr,s1[i]);    }    System.out.println(s2);    String fin ="";    for (int i = 0; i < 6; i++) {      fin += s2.charAt(i);    }    byte[] br = fin.getBytes();    for (int i = 0; i < br.length; i++) {      System.out.print(decimalToHex(br[i]) + "\t");    }  }  public static String resolve(char[][] arr,String s1){    int a = 99;    int b = 99;    int a1 = 99;    int b1 = 99;    String res = "";    for (int i = 0; i < arr.length; i++) {      for (int j = 0; j < arr[i].length; j++) {        if((arr[i][j] == s1.charAt(0))){          a = i;          b = j;        }else if(arr[i][j] == s1.charAt(1)){          a1 = i;          b1 = j;        }        if((a != 99) && (b !=99) && (a1 !=99) && (b1 != 99)){          if(((a1 - a) !=0) && (((b1 - b) !=0))){            res = "" + arr[a][b1] + arr[a1][b];          }else if((a1 - a == 0) && (b1 - b != 0)){            if((b == 4)){              res = "" + arr[a][0] + arr[a1][b1+1];            }else if(b1 == 4){              res = "" + arr[a][b+1] + arr[a1][0];            }else{              res = "" + arr[a][b+1] + arr[a1][b1+1];            }          }else if((a1 - a !=0 ) && (b1 - b == 0)){            if((a == 4)){              res = "" + arr[0][b] + arr[a1+1][b1];            }else if(a1 == 4){              res = "" + arr[a+1][b] + arr[0][b1];            }else{              res = "" + arr[a+1][b] + arr[a1+1][b1];            }          }        }      }    }    return res;  }  public static String removeMethod(String s) {    StringBuffer sb = new StringBuffer();    int len = s.length();    for (int i = 0; i < len; i++) {      char c = s.charAt(i);      if (s.indexOf(c) ==s.lastIndexOf(c)) {//此字符第一次位置和最后位置一致 即肯定沒有重復的直接添加        sb.append(c);      } else {//同理 次字符出現過多次        int fristposition=s.indexOf(c);//次字符第一次出現的位置        if(fristposition==i){//第一次出現的位置和當前位置一致 即第一次出現添加          sb.append(c);        }      }    }    return sb.toString();  }  public static String decimalToHex(byte decimal) {    String hex = "";    while(decimal != 0) {      int hexValue = decimal % 16;      hex = toHexChar(hexValue) + hex;      decimal = (byte)(decimal / 16);    }    return hex;  }  //將0~15的十進制數轉換成0~F的十六進制數  public static char toHexChar(int hexValue) {    if(hexValue <= 9 && hexValue >= 0)      return (char)(hexValue + '0');    else      return (char)(hexValue - 10 + 'A');  }}

看完上述內容,你們掌握java中怎么實現一個波雷費密碼算法的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黄陵县| 庄河市| 盐城市| 锡林浩特市| 安福县| 万全县| 固始县| 巴楚县| 余庆县| 葵青区| 潜山县| 南乐县| 洱源县| 阿克苏市| 兰溪市| 昭通市| 新营市| 土默特左旗| 滨州市| 烟台市| 垦利县| 闽清县| 铜鼓县| 永济市| 台中市| 嘉黎县| 花垣县| 汝州市| 张北县| 若羌县| 简阳市| 南召县| 彭水| 邓州市| SHOW| 永兴县| 红桥区| 马鞍山市| 乌苏市| 方城县| 宁远县|