java中怎么實(shí)現(xiàn)一個(gè)波雷費(fèi)密碼算法,相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。
創(chuàng)新互聯(lián)建站專注于網(wǎng)站建設(shè)|
網(wǎng)站維護(hù)|優(yōu)化|托管以及網(wǎng)絡(luò)推廣,積累了大量的網(wǎng)站設(shè)計(jì)與制作經(jīng)驗(yàn),為許多企業(yè)提供了網(wǎng)站定制設(shè)計(jì)服務(wù),案例作品覆蓋
成都小攪拌車等行業(yè)。能根據(jù)企業(yè)所處的行業(yè)與銷售的產(chǎn)品,結(jié)合品牌形象的塑造,量身建設(shè)品質(zhì)網(wǎng)站。
一、算法描述
波雷費(fèi)密碼是一種對(duì)稱式密碼,是首種雙字母取代的加密法。
下面描述算法步驟:
1、從1號(hào)二維碼M05,提取明文信息和密文,M05格式:,其中明文xxx…xxx,密鑰部分信息為yyy…yyy中的提取所有英文字母信息。
2、將提取的英文字母作密匙。除去重復(fù)出現(xiàn)的字母。將密匙的字母逐個(gè)逐個(gè)加入5×5的矩陣內(nèi),剩下的空間將未加入的英文字母依A-Z的順序加入。(將Q去除)
3、將要加密的訊息分成兩個(gè)一組。若組內(nèi)的字母相同,將X加到該組的第一個(gè)字母后,重新分組。若剩下一個(gè)字,也加入X字。
4、在每組中,找出兩個(gè)字母在矩陣中的地方。若兩個(gè)字母不同行也不同列,在矩陣中找出另外兩個(gè)字母,使這四個(gè)字母成為一個(gè)長方形的四個(gè)角。 若兩個(gè)字母同行,取這兩個(gè)字母右方的字母(若字母在最右方則取最左方的字母)。 若兩個(gè)字母同列,取這兩個(gè)字母下方的字母(若字母在最下方則取最上方的字母)。
5、新找到的兩個(gè)字母就是原本的兩個(gè)字母加密的結(jié)果。
6、取密文前3個(gè)字符與后三個(gè)字符(大寫字母)作為對(duì)應(yīng)6位的紅外報(bào)警開啟碼。
二、算法過程示例
例:二維碼內(nèi)容為:。
1.明文信息hidethegold和密匙playfairexample
2.根據(jù)密鑰形成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.就會(huì)得到密文:“BM ND ZB XD KY GE”,
5.取密文前6個(gè)字符(大寫字母)對(duì)應(yīng)6位的報(bào)警碼:0X42,0X4D,0X4E,0X44, 0X5A, 0X42
三、具體代碼如下:
import sun.applet.Main;public class blf { public static void main(String[] args) { String s = ""; 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; //把余數(shù)補(bǔ)全 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)) {//此字符第一次位置和最后位置一致 即肯定沒有重復(fù)的直接添加 sb.append(c); } else {//同理 次字符出現(xiàn)過多次 int fristposition=s.indexOf(c);//次字符第一次出現(xiàn)的位置 if(fristposition==i){//第一次出現(xiàn)的位置和當(dāng)前位置一致 即第一次出現(xiàn)添加 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的十進(jìn)制數(shù)轉(zhuǎn)換成0~F的十六進(jìn)制數(shù) public static char toHexChar(int hexValue) { if(hexValue <= 9 && hexValue >= 0) return (char)(hexValue + '0'); else return (char)(hexValue - 10 + 'A'); }}
看完上述內(nèi)容,你們掌握java中怎么實(shí)現(xiàn)一個(gè)波雷費(fèi)密碼算法的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
本文名稱:java中怎么實(shí)現(xiàn)一個(gè)波雷費(fèi)密碼算法-創(chuàng)新互聯(lián)
文章地址:
http://weahome.cn/article/dgehoo.html