Шифр случайной замены Java

1

Я делаю шифрование случайного замещения в Java. В принципе, программа запрашивает у вас предложение, вы вводите предложение, оно принимает предложение и использует случайно сгенерированный алфавит, шифрует его. У пользователя есть выбор для шифрования или дешифрования. Затем зашифрованный шифрованный текст отображается на экране. Если пользователь этого захочет, программа расшифрует шифр и покажет оригинальное текстовое сообщение.

Вот что у меня есть до сих пор:

    Random gen = new Random();
    PrintWriter write = new PrintWriter(new File("CryptCode.txt"));
    char[] chars = new char[] {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'};
                                //'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};
    char[] cryptList = new char[26];

    int tracker = 0;
    while(tracker < 26)
    {
        int num = gen.nextInt(26);
        if(cryptList[num] == '\u0000')
        {
        cryptList[num] = chars[tracker];
        tracker++;
        }
    }

    for(int i = 0; i < 26; i++)
    {
        write.println(chars[i] + " " + cryptList[i]);
    }
    write.close();

Это просто генерирует случайный алфавит. Я понятия не имею, как бы я мог реализовать настоящий метод шифрования. Я могу обрабатывать файл IO и подсказки пользователю самостоятельно. Я просто не могу понять, как создать алгоритм подстановки. Любая помощь приветствуется. Вероятно, я могу выяснить метод дешифрования, как только у меня будет метод шифрования передо мной, но на данный момент я понятия не имею, как действовать. Благодарю!

Теги:
encryption

2 ответа

1

Я сделал это раньше, и именно так я это сделал:

private static char[] alphabet = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i',
'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v',
'w', 'x', 'y', 'z'};

public static char[] shiftAlphabet(int shift)
{
    char[] newAlpha = new char[26];
    for (int i = 0; i < 26; i++)
    {
        if(((i + shift) < 26) && ((i + shift) >= 0))
        {
            newAlpha[i]  = alphabet[i + shift];
        }
        else if ((i + shift) >= 26)
        {
            newAlpha[i] = alphabet[i + shift - 26];
        }
    }
    return newAlpha;
}
public static String encrypt(String s, int shift)
{
    String e = "";
    for(int i = 0; i < s.length(); i++)
    {
        char letter = s.charAt(i);
        if (letter != ' ')
        {
            int f = find(alphabet, letter);
            if(((f + shift) < 26) && ((f + shift) >= 0))
            {
                letter  = alphabet[f + shift];
            }
            else if ((f + shift) >= 26)
            {
                letter = alphabet[f + shift - 26];
            }
            e = e + String.valueOf(letter);
        }
        else 
        {
            e = e + " ";
        }
    }
    return e;
}
public static int find(char[] c, char c2)
{
    int w = 0;
    for(int i = 0; i < c.length; i++)
    {
        if(c[i] == (c2))
            w = i;
    }
    return w;
}

Первый метод сдвигает алфавит на некоторое целое число, а второй метод шифрует сообщение, используя последний метод, который находит расположение букв в алфавите (он возвращает значение от 0 до 25). Таким образом, используя эти методы, в основном методе вы можете создать случайное число от 1 до 26 и использовать его в качестве переменной "shift", а затем запросить у пользователя сообщение, которое он хотел бы зашифровать.

  • 0
    Я уже сделал шифр замещения Цезаря, что делает этот код. Вместо целочисленного сдвига я создаю совершенно случайный алфавит. Например, первые пять букв этого случайного алфавита могут быть «hwreu». После этого поколения каждое «a» в пользовательском вводе заменяется на «h», каждое «b» на «w» и так далее, и так далее. Я не реализую сдвиг в реальном алфавите, я создаю новый. Любые мысли о том, как я мог бы выполнить шифрование на этом этапе? Спасибо
  • 0
    Как бы вы создали этот случайный алфавит? Можете ли вы разместить код здесь. Я мог бы помочь вам оттуда.
0

Алгоритм замены означает, что он заменяет символ с некоторым символом

вы можете пойти несколькими способами

1.substitute the character with nth character from now.
     example: a is replaced by e
              b is replaced by f
2.substitute the character with (n+i)th character from now. to replace abf
     example: a is replaced by f(a=1,n=5)
              b is replaced by g(b=2,n=5)
              f is replaced by m(f=3,n=5)

обычно каждый орган использует rot13 как один из подстановочных шифров, который заменяет 13-й символ строки

Ещё вопросы

Сообщество Overcoder
Наверх
Меню