java - 如何将字符串转换为位,然后将其分成两半并在一部分上执行一些功能,然后将其与另一个进行异或,然后使用 java 进行交换?
问题描述
是的,它只是 feistel 密码。我需要实现一个简单的程序来实现它,而不使用任何预先存在的代码。我认为我的主要问题是将字符串转换为位以对其执行某些功能?顺便说一句,我正在使用java,而且我不是那个专家。请帮我提供任何信息。你认为它可能会有所帮助..
这是我的代码:
public static String encrypt(String s) {
// convert to bits
int sByte = new BigInteger(s.getBytes()).intValue();
for(int i = 0 ; i<=1 ; i++) {
// split
String splitS1 = (""+sByte).substring(0,(""+sByte).length()/2);
String splitS2 = (""+sByte).substring((""+sByte).length()/2,(""+sByte).length());
// convert to int for function + xor
int spl1 = new BigInteger(splitS1.getBytes()).intValue();
int spl2 = new BigInteger(splitS2.getBytes()).intValue();
int F = 0;
// key based on i
if (i == 0)
F = spl2 + 0000111; // key 7
if (i == 1)
F = spl2 + 00001011; // key 11
// xor
int xOr = spl1^F;
// swap
sByte = spl2 + xOr;
}
// convert to String
String AfterEnc = new String(new BigInteger(""+sByte, 2).toByteArray());
return AfterEnc;
}
解决方案
我的主要问题是将字符串转换为位
执行以下操作:
import java.util.BitSet;
public class Main {
public static void main(String[] args) {
String str = "text";
byte[] strBytes = str.getBytes();
BitSet strBitSet = BitSet.valueOf(strBytes);
System.out.println("BitSet: " + strBitSet);
String strToBinary = bitSetToBinary(strBitSet);
System.out.println("Binary representation: " + strToBinary);
}
static String bitSetToBinary(BitSet bitSet) {
StringBuilder s = new StringBuilder();
for (int i = 0; i < bitSet.length(); i++) {
s.append(bitSet.get(i) == true ? 1 : 0);
}
return s.reverse().toString();
}
}
输出:
BitSet: {2, 4, 5, 6, 8, 10, 13, 14, 19, 20, 21, 22, 26, 28, 29, 30}
Binary representation: 1110100011110000110010101110100
[更新]
注意:我建议您在开头拆分字符串,然后BitSet
为这两个部分创建,例如
import java.util.BitSet;
public class Main {
public static void main(String[] args) {
String str = "text";
String part1 = str.substring(0, str.length() / 2);
String part2 = str.substring(str.length() / 2);
byte[] part1Bytes = part1.getBytes();
byte[] part2Bytes = part2.getBytes();
BitSet part1BitSet = BitSet.valueOf(part1Bytes);
BitSet part2BitSet = BitSet.valueOf(part2Bytes);
System.out.println("Part1 BitSet: " + part1BitSet);
System.out.println("Part2 before performing XOR: " + part2BitSet);
part2BitSet.xor(part1BitSet);// You can create a new BitSet for performing XOR. I am using an existing BitSet for test.
System.out.println("Part2 after performing XOR: " + part2BitSet);
}
}
输出:
Part1 BitSet: {2, 4, 5, 6, 8, 10, 13, 14}
Part2 before performing XOR: {3, 4, 5, 6, 10, 12, 13, 14}
Part2 after performing XOR: {2, 3, 8, 12}
推荐阅读
- excel - 如何删除通过导出访问子表单创建的excel文档的列?
- git - 从其他分支复制文件版本或提交而不覆盖当前版本?
- c++ - 从 EnumDesktopWindows 中仅识别应用程序窗口
- vb.net - 使用 PDFBox 1.8.9 和 VB Net 突出显示 PDF 中的单词
- c - 如何将结构从 Mac 上的 x86-64 程序集传递给 C 函数(NASM)
- r - 根据列值对行进行分组并在 R 中保留具有最小值的行
- laravel - Laravel 如果相关集合删除父级
- elixir - 对订阅应用过滤器
- c# - 如何在不知道 ID 号的情况下从数据库中检索数据?
- amazon-web-services - 尝试从 AWS beanstalk 配置文件中获取详细信息