0

我想知道如何操作 ByteArray 中的位。我需要的是根据我拥有的“表格”移动位。

桌子:

Bit 0 -> Bit 26
Bit 1 -> Bit 31
Bit 2 -> Bit 17
...
Bit 31 -> Bit 5

我使用这种方法将 ByteArray 转换为 BitArray

public static BitArray ByteArraytoBitArray(byte[] bytes)
{
    BitArray bits = new BitArray(bytes);
    return bits;
}

但是我被困在那里,我不知道如何根据表格移动位,然后返回到 ByteArray。

编辑:

代码片段:

public static byte[] StringToByteArray(String hex)
{
    int NumberChars = hex.Length;
    byte[] bytes = new byte[NumberChars / 2];
    for (int i = 0; i < NumberChars; i += 2)
        bytes[i / 2] = Convert.ToByte(hex.Substring(i, 2), 16);
    return bytes;
}
private void button3_Click(object sender, EventArgs e)
{
    string featherearring = "00804804A02A1CA20100000000000000D2F8B6FABBB700000000000000000000";
    var strarray = StringToByteArray(featherearring);

    byte[] strarray_comp = Enc.Encrypt(strarray);

    string conv = BitConverter.ToString(strarray_comp);
    MessageBox.Show(conv.Replace("-", ""));
}



public static byte[] BitArrayToByteArray(BitArray bits)
{
    byte[] bytes = new byte[bits.Length / 8];
    bits.CopyTo(bytes, 0);
    return bytes;
}
public static byte[] Encrypt(byte[] input)
{
    BitArray source = new BitArray(input);
    BitArray target = new BitArray(source.Length);

    target[26] = source[0];
    target[31] = source[1];
    target[17] = source[2];
    target[10] = source[3];
    target[30] = source[4];
    target[16] = source[5];
    target[24] = source[6];
    target[2] = source[7];
    target[29] = source[8];
    target[8] = source[9];
    target[20] = source[10];
    target[15] = source[11];
    target[28] = source[12];
    target[11] = source[13];
    target[13] = source[14];
    target[4] = source[15];
    target[19] = source[16];
    target[23] = source[17];
    target[0] = source[18];
    target[12] = source[19];
    target[14] = source[20];
    target[27] = source[21];
    target[6] = source[22];
    target[18] = source[23];
    target[21] = source[24];
    target[3] = source[25];
    target[9] = source[26];
    target[7] = source[27];
    target[22] = source[28];
    target[1] = source[29];
    target[25] = source[30];
    target[5] = source[31];

    return BitArrayToByteArray(target);
}

我输入字节数组是“00804804A02A1CA20100000000000000D2F8B6FABBB700000000000000000000”我与zimdanen的代码输出为“5012000000000000000000000000000000000000000000000000000000000000”,它应该是“501200002FD901000000000400000000BFE8C4DB140D11F40000000000000000”正如你所看到的,它获得的第2右字节,但其余部分均为空。

4

2 回答 2

1

它需要到位吗?您可以创建一个新的 BitArray 并复制这些位:

BitArray source = new BitArray(bytes);

// Create target array.
BitArray target = new BitArray(source.Length);

// Map bits.
// ...
target[26] = source[0];
// ...

或者,根据您要如何维护映射“表”,您可以这样做:

// Setup mapping - <source, target>.
Dictionary<int, int> mapping = new Dictionary<int, int>();
// ...
mapping.Add(0, 26);
// ...

BitArray source = new BitArray(bytes);

// Create target array.
BitArray target = new BitArray(source.Length);

// Map bits.
foreach (int sourceIndex in mapping.Keys)
{
    int targetIndex = mapping[sourceIndex];
    target[targetIndex] = source[sourceIndex];
}
于 2012-05-03T17:12:57.070 回答
1

您的第一个问题是您有一个 32 字节的数组,要转换为BitArray. 您会发现该source.Count属性的值是 256. target.Count,而另一方面,只有 32。因此您的Encrypt方法只更改了位数组的前 32 位,这对应于四个字节 - 八个十六进制字符。数组的其余部分将为空值。

您可以通过在执行复制之前更改BitArrayToByteArray方法以使用 0xFF 填充目标来验证这一点:

public static byte[] BitArrayToByteArray(BitArray bits)
{
    byte[] bytes = new byte[bits.Length / 8];
    // Fill the array with 0xFF to illustrate.
    for (int i = 0; i < bytes.Length; ++i)
    {
        bytes[i] = 0xFF;
    }
    bits.CopyTo(bytes, 0);
    return bytes;
}

我想你会发现结果是“50120000FFFFFF....”

很难确切地说出您要做什么。如果您想打乱字符串中的字节,则无需使用BitArray. 如果你真的想加扰这些位,那么你需要加扰所有的位。如果没有有关您要做什么的更多信息,我没有任何建议。除了也许您应该使用许多现有加密算法中的一种,而不是尝试使用自己的加密算法。

于 2012-05-04T05:08:25.420 回答