Порт jBCrypt 0.3 C # (BCrypt.net) - PullRequest
       55

Порт jBCrypt 0.3 C # (BCrypt.net)

2 голосов
/ 08 февраля 2010

После изучения ошибки в исходном порте jBCrypt v0.1 C #: BCrypt.net ( Связанный вопрос ). Я решил сравнить новый код jBCrypt со старым портом C #, чтобы найти несоответствия и потенциальные проблемы, такие как ошибка соответствующего вопроса.

Вот что я нашел:

// original java (jBCrypt v0.3):
private static int streamtoword(byte data[], int offp[]) {
        int i;
        int word = 0;
        int off = offp[0];

        for (i = 0; i < 4; i++) {
            word = (word << 8) | (data[off] & 0xff);
            off = (off + 1) % data.length;
        }

        offp[0] = off;
        return word;
}


// port to C# :
private static uint StreamToWord(byte[] data, ref int offset)
{

    uint word = 0;

    for (int i = 0; i < 4; i++)
    {
        // note the difference with the omission of "& 0xff"
        word = (word << 8) | data[offset];
        offset = (offset + 1) % data.Length;
    }

    return word;
}

если предыдущее неверно, исправят ли следующие?

private static uint StreamToWord(byte[] data, ref int[] offsetp)
{

    uint word = 0;
    int offset = offsetp[0];
    for (int i = 0; i < 4; i++)
    {
        word = (word << 8) | (uint)(data[offset] & 0xff);
        offset = (offset + 1) % data.Length;
    }

    offsetp[0] = offset;

    return word;
}

1 Ответ

5 голосов
/ 08 февраля 2010

В версии Java требуется & 0xff, потому что в Java байты подписаны. (Некоторые утверждают, что это ошибка.)

В C # байты без знака , поэтому & 0xff не требуется.

...