java实现波雷费密码算法示例代码
作者:是赵先森啊 发布时间:2022-09-14 23:30:28
一、算法描述
波雷费密码是一种对称式密码,是首种双字母取代的加密法。
下面描述算法步骤:
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');
}
}
四、运行结果:
来源:https://blog.csdn.net/Dimpies/article/details/104004838


猜你喜欢
- strings.xml 有很多需要注意的地方和一些小技巧,知道了这些可以让你的 Android 应用更加规范易用,感兴趣的小伙伴们可以参考一
- 先看看效果图:1、XML布局引入<com.net168.lib.SortTabLayout android:id=&quo
- 概述附件,指随同文件发出的有关文件或物品。在PDF文档中,我们可以添加同类型的或其他类型的文档作为附件内容,而PDF中附件也可以分为两种存在
- JSONObject的使用 一、 JSON对象的使用:String content = "{'username&
- Android镂空字体的实现效果图,感兴趣的朋友可以参考实现代码。效果图:记录一下...自定义TextViewpublic class Ho
- Random类 (java.util) Ran
- 本文讲述了Android编程中关于单线程模型的理解与分析。分享给大家供大家参考,具体如下:当一个Android程序启动时,Android系统
- 本文实例为大家分享了Android创建发送和接收短信应用的简单实现过程,供大家参考,具体内容如下一、接收短信项目的结构如下:一个简单的接收和
- 首先介绍一些乐观锁与悲观锁:悲观锁:总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个
- 先说一句:密码是无法解密的。大家也不要再问松哥微人事项目中的密码怎么解密了!密码无法解密,还是为了确保系统安全。今天松哥就来和大家聊一聊,密
- C++在vscode中的多文件编程相信有很多的小伙伴在一开始的时候,都会对vscode的多文件编程有很多的疑问,网上也有很多的教学,不过网上
- 序列帧动画经常用到,最直接的方式就是用Animation录制。但某些情况下这种方式并不是太友好,需要靠代码的方式进行序列帧动画的实现。代码实
- 这篇文章主要介绍了JAVA使用 * 对象进行敏感字过滤代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值
- 页面代码:<%@ page language="java" contentType="text/html
- 本文实例为大家分享了C#实现计算器窗体程序的具体代码,供大家参考,具体内容如下功能设计1、计算器中,添加 0-9 共十个数字键。2、计算器中
- 本文实例讲述了Winform中GridView分组排序功能实现方法。分享给大家供大家参考。具体实现方法如下:一、问题:由于客户最近要扩充公司
- 概述:EventBus是一款针对Android优化的发布/订阅事件总线。主要功能是替代Intent,Handler,BroadCast在Fr
- 本文实例讲述了C#遍历操作系统下所有驱动器的方法。分享给大家供大家参考。具体分析如下:这里先通过DriveInfo类的GetDrivers方
- 我们springboot项目有自己默认的配置文件,一般地由application.yml和bootstrap.yml组成,前者是模块的配置,
- 在我们平时的开发中会经常用到Image控件,通过设置Image控件的Source属性,我们可以加载图