0

我正在尝试使用Java创建一个流密码,在其中我从文件中获取纯文本对其进行加密(使用带有种子值的随机密钥的简单异或)并将其存储在不同的文件中,然后解密,再次获取密文从文件中解密(与加密密钥相同的 XOR 操作)并存储在文件中。

但是当我尝试加密大字符串时遇到了问题。字符串的一半被正确解密,但另一半仍然是不可读的格式。

                FileReader fileReader = new FileReader(file);

                // Always wrap FileReader in BufferedReader.
                BufferedReader bufferedReader = 
                    new BufferedReader(fileReader);

                FileWriter fileWriter =
                        new FileWriter(file2);

                    // Always wrap FileWriter in BufferedWriter.
                    BufferedWriter bufferedWriter =
                        new BufferedWriter(fileWriter);


                while((line = bufferedReader.readLine()) != null) {
                    sb = new StringBuffer (line);

                    int lenStr = line.length();
                    int lenKey = String.valueOf(random).length();

                    // For each character in our string, encrypt it...
                    for ( int i = 0, j = 0; i < lenStr; i++, j++ ) 
                    {
                       if ( j >= lenKey ) j = 0;  // Wrap 'round to beginning of key string.

                       //
                       // XOR the chars together. Must cast back to char to avoid compile error. 
                       //
                       String key = random + "";
                       bufferedWriter.write((char)(line.charAt(i) ^ key.charAt(j)));

                    }
                }   

                // Always close files.
                bufferedReader.close();  
                bufferedWriter.close();
4

1 回答 1

0

您在没有足够小心的情况下混合了二进制和字符和字符串。字符的异或很可能导致字符不代表字符串。如果两个相同的字符被异或在一起,那么结果将是一个空字符,通常解释为 FILE 的 END。

相反,最好在异或时保持一切二进制。XOR 是二元运算,而不是对字符的运算。所以你改用字节数组。

于 2016-02-27T00:06:42.890 回答