Caesar加密的ASCII文本部分解密

时间:2017-01-22 10:09:44

标签: java encryption cryptography ascii

我试图通过蛮力解密一个Caesar编码的基本256 ASCII文本。 有问题的文字是:

dy}uƒ0^u‡0b}q~K‹lvAlv‚}q~lv€‚Blvsxq‚ƒu„B0c‰}r|K‹lvBlvƒ‡yƒƒlv€‚Blvsxq‚ƒu„@0Q‚yq|K‹lvClv‚}q~lv€‚Blvsxq‚ƒu„@0\yru‚q„y~0cu‚yv‹l:lvq|„0dy}uƒ0^u‡0b}q~K‹lvDlvƒ‡yƒƒlv€‚Blvsxq‚ƒu„@0\yru‚q„y~0cq~ƒ‹l:lvq|„0Q‚yq|K‹lvElv‚}q~lv€‚@lvsxq‚ƒu„ABH0dy}uƒ0^u‡0b}q~K‹lvFlv~y|l

使用这个小程序:

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;

public class Run {
    private static FileWriter fr;
    static String b;
    private static BufferedReader br;

    public static void main(String[] args) throws IOException {

        // encrypted file
        File enc_f = new File("caesar.rtf.enc");
        //decrypted file
        File dec_f = new File("caesar.rtf.dec");

        // init variables
        String text_enc = new String();
        String text_dec = new String();

        // read file
        br = new BufferedReader(new FileReader(enc_f));
        for (String line; (line = br.readLine()) != null; text_enc += line);
        char[] stringToCharArray = text_enc.toCharArray();

        // parse file and convert string to char
        for (int shift = 0; shift < 257; shift++) {

            for (char output : stringToCharArray) {

                // convert ascii to int
                int ascii = (int) output;

                // shift 
                ascii = ascii + shift;
                ascii = ascii % 256;

                // convert back to ascii
                char chTemp = (char) ascii;
                text_dec += chTemp;

            }

            // visual representation
            text_dec += System.lineSeparator();
            text_dec += System.lineSeparator();
            text_dec += shift;
            text_dec += System.lineSeparator();
            System.out.println(shift);

            // write decrypted file
            fr = new FileWriter(dec_f);
            fr.write(text_dec);

        }
        fr.close();
    }
}

运行程序后,我得到班次号码239的部分解密文本(这只是整个文件的一部分,以保持执行时间很短):

Timeí Neí Roman;íí\f1\fíoman\fííí2\fchaííeí2 Símbol;íí\f2\fííiíí\fííí2\fchaííeí0 Aíial;íí\f3\fíoman\fííí2\fchaííeí0 Libeíaíion Seíifí\*\falí Timeí Neí Romaní;íí\f4\fííiíí\fííí2\fchaííeí0 Libeíaíion Saníí\*\falí Aíialí;íí\f5\fíoman\fííí0\fchaííeí128 Timeí Neí Roman;íí\f6\fnil\

正如可以看到的那样,我可以阅读时间新罗马,但也可以阅读它不应该的í,我无法理解为什么,好像转变不正确而不是所有文本应该是不仅仅是错误的一部分。加密文本也可以正确解密。 如果您有任何想法,我们将很乐意接受提示。

1 个答案:

答案 0 :(得分:2)

你犯了一个非常基本的错误:将二进制/字节与字符串混淆。

没有&#34; 256 ASCII&#34;,ASCII是7位,即在[0..127]内编码,前32和最后一个值是控制字符< / em>的

您所说的是 bytes ,应该对这些操作执行操作。如果在Java中对字节执行计算,它将自动在0..255范围内。你必须要小心,尽管这个字节没有被提升&#34;到一个整数,然后立即使用(byte)进行回退。

因此,除了最终打印输出外,您的操作都应该是字节数。使用ReaderWriter可能会丢失数据,因为某些字符可能会被遗漏。只需直接使用流,然后在任何文本阅读器中查看输出。

您当然也可以使用输出在某些字节值(有效字符编码)之间的事实来测试您的解决方案是否正确。

请注意,我们无法测试您作为您的输入&#34; string&#34;很可能已经致残了。如果要在此处打印,请使用base 64或hexadecimals对其进行编码。