Несогласованные результаты записи, затем чтения с байтовым массивом и DataOutputStream - PullRequest
1 голос
/ 05 июня 2011

Короткая версия: Я записываю 8-байтовый байтовый массив, заполненный случайными байтами, на диск, используя DataOutputStream, а затем считываю его обратно с DataInputStream в другом методе. Данные не кажутся одинаковыми. С чего мне начать искать проблемы?

Длинная версия: У меня есть кусок кода, который выполняет шифрование на основе пароля с использованием библиотек javax.crypto. Я генерирую 8-байтовую случайную соль, используя генератор случайных чисел, а затем использую счетчик итераций 1000 для генерации ключа.

Когда я пишу файл, он идет в формате:

[ 8-byte Salt ][int iteration count][encrypted payload]

Когда я читаю начало файла, чтобы восстановить параметры для восстановления ключа, массив байтов не выглядит так, как написано. Однако число итераций успешно восстановлено.

Весь фрагмент кода здесь:

http://hg.kurt.im/479hw3/src/0c3c11f68f26/src/csc479_hw3/PBE.java

С соответствующими частями ниже:

boolean encrypt(char[] password, String fileName){
    Random randy = new Random();
    byte[] salt = new byte[8];
    randy.nextBytes(salt);
    System.out.println("Salt: "+salt);

    try{
        File inFile = new File(fileName);
        File outFile = new File(fileName+."encrypted);
        DataOutputStream dOS = new DataOutputStream(new FileOutputStream(outFile));

        dOS.write(salt);
        dOS.flush();
        dOS.writeInt(1000);
        dOS.flush();
        dOS.close();
        /* Snip a bunch of stuff currently commented out related to encryption */
    }catch(Exception e){
         e.printStackTrace();
         return false;
    }
    return true;
}

boolean decrypt(char[] password, string fileName, string outFileName){
    byte[] salt = new byte[8];
    try{
        DataInputStream dIS = new DataInputStream(new FileInputStream(newFile(fileName)));
        dIS.read(salt,0,salt.length);
        int iterationCount = dIS.readInt();

        System.out.println("Recovered salt: "+salt);//Different than above written salt
        System.out.println("Recovered count: "+iterationCount);//Same as above
        /*Snip some more commented out crypto */
    }catch (Exception e){
        e.printStackTrace();
        return false;
    }
    return true;
}

С включенным шифровальным кодом я получаю полушифрованный файл. Без этого я получаю только непоследовательную запись, затем читаю.

1 Ответ

2 голосов
/ 05 июня 2011

Вы распечатываете байтовый массив, просто используя его реализацию toString(), которая не показывает данные, только хеш-код.

Попробуйте использовать Arrays.toString(salt) вместо:

System.out.println("Recovered salt: " + Arrays.toString(salt));

(И точно так же, когда выписываете это.)

Я подозреваю теперь вы увидите, что вы все время правильно читали соль.

...