전통적인 암호

두 번째 장에서는 현대 암호화의 기본 사항에 대해 논의했습니다. 우리는 다양한 암호화 기술이 기본 도구로 간주되는 도구 키트와 암호화를 동일시했습니다. 이러한 도구 중 하나는 암호화 및 암호 해독에 사용되는 키가 동일한 대칭 키 암호화입니다.

이 장에서는이 기술과 다양한 암호 시스템을 개발하기위한 응용 프로그램에 대해 자세히 설명합니다.

이전 암호화 시스템

계속 진행하기 전에 역사적인 암호 시스템에 대한 몇 가지 사실을 알아야합니다.

  • 이 모든 시스템은 based on symmetric key encryption 계획.

  • 이러한 시스템이 제공하는 유일한 보안 서비스는 정보의 기밀성입니다.

  • 디지털이고 데이터를 이진수로 취급하는 현대 시스템과 달리 초기 시스템은 알파벳을 기본 요소로 사용했습니다.

이러한 초기 암호화 시스템을 암호라고도합니다. 일반적으로 암호는 암호화와 해당 복호화를 모두 수행하기위한 일련의 단계 (알고리즘)에 불과합니다.

시저 암호

일반 텍스트의 각 문자가 다른 문자로 대체되어 암호문을 형성하는 단일 알파벳 암호입니다. 가장 단순한 형태의 대체 암호 체계입니다.

이 암호화 시스템은 일반적으로 Shift Cipher. 개념은 각 알파벳을 0에서 25 사이의 고정 숫자로 '이동'되는 다른 알파벳으로 대체하는 것입니다.

이러한 유형의 체계의 경우 발신자와 수신자 모두 알파벳 이동을위한 '비밀 이동 번호'에 동의합니다. 0에서 25 사이의이 숫자가 암호화 키가됩니다.

'Caesar Cipher'라는 이름은 'Shift of three'가 사용될 때 Shift Cipher를 설명하는 데 가끔 사용됩니다.

시프트 암호 과정

  • 일반 텍스트 문자를 암호화하기 위해 보낸 사람은 슬라이딩 눈금자를 첫 번째 일반 텍스트 문자 집합 아래에 놓고 비밀 이동 위치 수만큼 왼쪽으로 밀어 넣습니다.

  • 그런 다음 일반 텍스트 문자는 아래의 슬라이딩 눈금자에있는 암호문 문자로 암호화됩니다. 이 프로세스의 결과는 합의 된 세 위치 이동에 대한 다음 그림에 나와 있습니다. 이 경우 일반 텍스트 'tutorial'은 암호문 'WXWRULDO'로 암호화됩니다. 다음은 3의 시프트에 대한 암호문 알파벳입니다-

  • 암호문을 수신하면 비밀 시프트를 알고있는 수신자는 암호문 알파벳 아래에 슬라이딩 눈금자를 놓고 합의 된 시프트 번호 (이 경우 3)만큼 오른쪽으로 슬라이드합니다.

  • 그런 다음 암호문 문자를 아래의 슬라이딩 눈금자에있는 일반 텍스트 문자로 바꿉니다. 따라서 암호문 'WXWRULDO'는 '튜토리얼'로 해독됩니다. Shift 3으로 인코딩 된 메시지를 해독하려면 아래와 같이 '-3'의 이동을 사용하여 일반 텍스트 알파벳을 생성하십시오.

보안 가치

Caesar Cipher는 not a secure시도 할 수있는 키는 26 개뿐이기 때문입니다. 공격자는 사용 가능한 제한된 컴퓨팅 리소스로 전체 키 검색을 수행 할 수 있습니다.

단순 대체 암호

Caesar Cipher의 개선 사항입니다. 이 체계는 알파벳을 숫자로 이동하는 대신 알파벳 문자의 일부 순열을 사용합니다.

예를 들어, AB… ..YZ 및 ZY …… BA는 알파벳의 모든 문자에 대한 두 가지 명백한 순열입니다. 순열은 뒤죽박죽 알파벳 세트에 불과합니다.

알파벳 26 개 문자로 가능한 순열은 26 개입니다! (26의 계수) 4x10 26 과 같습니다 . 발신자와 수신자는 이러한 가능한 순열 중 하나를 암호문 알파벳으로 선택할 수 있습니다. 이 순열은 체계의 비밀 키입니다.

단순 대체 암호 프로세스

  • 알파벳 A, B, C, ..., Z를 자연스러운 순서로 씁니다.

  • 발신자와 수신자는 알파벳 문자의 무작위로 선택된 순열을 결정합니다.

  • 자연 순서 알파벳 아래에 선택한 알파벳 문자 순열을 작성하십시오. 암호화의 경우 발신자는 표에서 바로 아래에있는 순열 문자를 대체하여 각 일반 텍스트 문자를 바꿉니다. 이 프로세스는 다음 그림에 나와 있습니다. 이 예에서 선택한 순열은 K, D, G, ..., O입니다. 일반 텍스트 '포인트'는 'MJBXZ'로 암호화됩니다.

다음은 암호문 문자의 순서가 핵심 인 뒤섞인 암호문 알파벳입니다.

  • 암호문을 수신하면 무작위로 선택한 순열을 알고있는 수신자는 맨 아래 행의 각 암호문 문자를 맨 위 행의 해당 일반 텍스트 문자로 바꿉니다. 암호문 'MJBXZ'는 '포인트'로 해독됩니다.

보안 가치

단순 대체 암호는 Caesar 암호에 비해 상당히 개선되었습니다. 가능한 키의 수는 많으며 (26 개!) 최신 컴퓨팅 시스템조차도 시스템을 파괴하기 위해 무차별 대입 공격을 편안하게 시작할 수있을만큼 강력하지 않습니다. 그러나 Simple Substitution Cipher는 단순한 디자인을 가지고 있으며 명백한 순열을 선택하면 디자인 결함이 발생하기 쉽습니다.이 암호 시스템은 쉽게 깨질 수 있습니다.

단 알파벳 및 다중 알파벳 암호

Monoalphabetic cipher는 지정된 키에 대해 각 일반 알파벳의 암호 알파벳이 암호화 프로세스 전체에서 고정되는 대체 암호입니다. 예를 들어 'A'가 'D'로 암호화 된 경우 해당 일반 텍스트에서 발생하는 횟수에 관계없이 'A'는 항상 'D'로 암호화됩니다.

이 장의 앞부분에서 논의한 모든 대체 암호는 단일 알파벳입니다. 이러한 암호는 암호화 분석에 매우 취약합니다.

Polyalphabetic Cipher는 암호화 과정에서 일반 알파벳의 암호 알파벳이 다른 위치에서 다를 수있는 대체 암호입니다. 다음 두 가지 예는playfair and Vigenere Cipher are polyalphabetic ciphers.

플레이 페어 암호

이 체계에서는 단순 대체 암호의 경우와 같이 단일 문자 대신 문자 쌍이 암호화됩니다.

playfair cipher에서는 처음에 키 테이블이 생성됩니다. 키 테이블은 일반 텍스트를 암호화하는 키 역할을하는 5x5 알파벳 그리드입니다. 25 개의 알파벳은 각각 고유해야하며 알파벳의 한 글자 (일반적으로 J)는 26 개 대신 25 개의 알파벳 만 필요하므로 테이블에서 생략됩니다. 일반 텍스트에 J가 포함 된 경우 I로 대체됩니다.

보낸 사람과받는 사람이 특정 키에 대해 제 살해 '튜토리얼'이라고 말합니다. 키 테이블에서 테이블의 첫 번째 문자 (왼쪽에서 오른쪽으로 이동)는 중복 문자를 제외한 구문입니다. 나머지 표는 자연 순서대로 알파벳의 나머지 문자로 채워집니다. 주요 테이블은-

Playfair Cipher의 과정

  • 먼저 일반 텍스트 메시지가 두 글자 쌍 (digraphs)으로 분할됩니다. 홀수 문자가있는 경우 마지막 문자에 Z가 추가됩니다. "돈 숨기기"메시지를 암호화하고 싶다고 가정 해 보겠습니다. 그것은 다음과 같이 쓰여질 것입니다-

    HI DE MO NE YZ

  • 암호화 규칙은 다음과 같습니다.

    • 두 글자가 같은 열에있는 경우 각 글자 아래에있는 글자를 가져옵니다 (아래에있는 경우 위로 돌아 가기).

  • 영형 아르 자형 나는 'H'와 'I'는 같은 열에 있으므로 그 아래에있는 문자를 사용하여 대체하십시오. 안녕 → QC
    에스
    이자형 에프 H
    케이 미디엄
    V W 엑스 와이
  • 두 글자가 같은 줄에있는 경우 각 글자의 오른쪽에있는 글자를 가져옵니다 (가장 오른쪽에있는 경우 왼쪽으로 돌아갑니다).

  • 영형 아르 자형 나는 'D'와 'E'는 같은 줄에 있으므로 오른쪽에있는 문자를 가져와 교체하십시오. DE → EF
    에스
    이자형 에프 H
    케이 미디엄
    V W 엑스 와이
  • 앞의 두 규칙 중 어느 것도 맞지 않으면 두 글자로 직사각형을 만들고 직사각형의 수평 반대쪽 모서리에있는 글자를 가져옵니다.

이 규칙을 사용하면 '튜토리얼'키를 사용하여 '숨기기'를 암호화 한 결과는 다음과 같습니다.

QC EF NU MF ZV

Playfair 암호 해독은 동일한 프로세스를 반대로 수행하는 것만 큼 간단합니다. 수신자는 동일한 키를 가지며 동일한 키 테이블을 생성 한 다음 해당 키를 사용하여 작성된 모든 메시지를 해독 할 수 있습니다.

보안 가치

또한 대체 암호이며 단순 대체 암호에 비해 깨지기 어렵습니다. 대체 암호의 경우와 마찬가지로 Playfair 암호에서도 암호 분석이 가능하지만 26 개의 다른 가능한 알파벳 대신 625 개의 가능한 문자 쌍 (25x25 알파벳)에 대한 것입니다.

Playfair 암호는 사용이 빠르고 특별한 장비가 필요하지 않기 때문에 중요하지만 중요하지 않은 비밀을 보호하는 데 주로 사용되었습니다.

Vigenere 암호

이 암호 체계는 텍스트 문자열 (예 : 단어)을 키로 사용하여 일반 텍스트에서 여러 번의 이동을 수행하는 데 사용됩니다.

예를 들어 키가 '포인트'라고 가정 해 보겠습니다. 키의 각 알파벳은 해당 숫자 값으로 변환됩니다.이 경우,

p → 16, o → 15, i → 9, n → 14 및 t → 20.

따라서 핵심은 16 15 9 14 20입니다.

Vigenere 암호 과정

  • 발신자와 수신자가 키를 결정합니다. '포인트'가 핵심이라고 말합니다. 이 키의 숫자 표현은 '16 15 9 14 20 '입니다.

  • 보낸 사람이 메시지를 암호화하려고합니다. '동남에서 공격'이라고 말합니다. 그는 다음과 같이 일반 텍스트와 숫자 키를 정렬합니다.

  • 그는 이제 각 일반 텍스트 알파벳을 아래에 적힌 숫자로 이동하여 아래와 같이 암호문을 생성합니다.

  • 여기에서 각 일반 텍스트 문자는 다른 양만큼 이동되었으며 그 양은 키에 의해 결정됩니다. 키는 메시지 크기보다 작거나 같아야합니다.

  • 복호화를 위해 수신자는 동일한 키를 사용하고 수신 된 암호문을 역순으로 이동하여 일반 텍스트를 얻습니다.

보안 가치

Vigenere Cipher는 표준 Caesar 암호를 조정하여 암호문에 대한 암호 분석의 효과를 줄이고 암호 시스템을 더욱 강력하게 만들어 설계되었습니다. 상당히more secure than a regular Caesar Cipher.

역사상 민감한 정치 및 군사 정보를 보호하기 위해 정기적으로 사용되었습니다. 그것은unbreakable cipher 암호 해석으로 인한 어려움 때문에.

Vigenere Cipher의 변형

Vigenere 암호에는 두 가지 특별한 경우가 있습니다.

  • 키워드 길이는 일반 메시지와 동일합니다. 이 사건은Vernam Cipher. 일반적인 Vigenere 암호보다 더 안전합니다.

  • Vigenere 암호는 완벽한 비밀을 지닌 암호 시스템이됩니다. One-time pad.

일회용 패드

상황은-

  • 키워드의 길이는 일반 텍스트의 길이와 같습니다.
  • 키워드는 무작위로 생성 된 알파벳 문자열입니다.
  • 키워드는 한 번만 사용됩니다.

보안 가치

Shift 암호를 일회용 패드와 비교해 보겠습니다.

Shift Cipher-쉽게 깨기

Shift 암호의 경우 전체 메시지가 1에서 25 사이의 이동을 가질 수 있습니다. 이것은 매우 작은 크기이며 무차별 대입이 매우 쉽습니다. 그러나 이제 각 문자가 1에서 26 사이의 개별 이동을 가지므로 가능한 키는 메시지에 대해 기하 급수적으로 증가합니다.

일회성 패드-부수기 불가능

일회성 패드로 "포인트"라는 이름을 암호화한다고 가정 해 보겠습니다. 5 글자 텍스트입니다. 무차별 대입으로 암호문을 해독하려면 키의 모든 가능성을 시도하고 (26 x 26 x 26 x 26 x 26) = 26 5 = 11881376 번 계산을 수행해야합니다 . 5 개의 알파벳이있는 메시지입니다. 따라서 더 긴 메시지의 경우 추가 알파벳이있을 때마다 계산이 기하 급수적으로 증가합니다. 이것은 무차별 대입으로 암호문을 해독하는 것을 계산적으로 불가능하게 만듭니다.

전치 암호

일반 텍스트의 알파벳 순서를 재 배열하여 암호문을 만드는 또 다른 유형의 암호입니다. 실제 일반 텍스트 알파벳은 대체되지 않습니다.

예를 들어 일반 텍스트가 특정 알파벳 너비로 가로로 쓰여지는 '단순 열 전치'암호가 있습니다. 그런 다음 그림과 같이 암호문을 세로로 읽습니다.

예를 들어, 일반 텍스트는 "황금 동상이 열한 번째 동굴에 있습니다"이고 선택된 비밀 임의 키는 "5"입니다. 이 텍스트는 키 값과 동일한 열 수를 사용하여 테이블에서 가로로 정렬합니다. 결과 텍스트는 아래와 같습니다.

암호문은 첫 번째 열에서 마지막 열까지 세로로 아래쪽으로 열을 읽어서 얻습니다. 암호문은 'gnuneaoseenvltiltedasehetivc'입니다.

복호화를 위해 수신자는 유사한 테이블을 준비합니다. 열 수는 키 번호와 같습니다. 행 수는 총 암호문 알파벳 수를 키 값으로 나누고 몫을 다음 정수 값으로 반올림하여 얻습니다.

그런 다음 수신자는 수신 된 암호문을 수직 아래로 왼쪽에서 오른쪽 열로 기록합니다. 텍스트를 얻기 위해 그는 수평으로 왼쪽에서 오른쪽으로 그리고 위에서 아래로 행을 읽습니다.