생일 공격
위키백과, 우리 모두의 백과사전.
생일 공격(birthday attack)은 암호학적 해시 함수의 해시 충돌을 찾아내는 암호해독 공격으로, 생일 문제의 확률적 결과를 기반으로 한다. 생일 문제에 따르면 해시 함수의 입력값을 다양하게 할수록 해시 값이 같은 두 입력값을 발견할 확률은 빠르게 증가한다. 따라서 모든 값을 대입하지 않고도 해시 충돌을 찾아낼 확률을 충분히 크게 만들 수 있다.
이론[편집]
가지의 값을 가지는 암호학적 해시 함수
에 대해,
인 두 입력값
를 찾는 것이 해시 충돌의 목표이다. 이를 찾기 위해서
가지의 입력값을 임의로 선택한 후 해시 값을 비교한다고 할 때, 해시 충돌을 찾을 확률은 다음과 같다.
를 해시 충돌을 찾을 확률이
이상이기 위한 입력값의 가짓수라고 하면
의 식에서부터 다음의 값이 유도된다.
여기에서
로 두면
를 얻는다.
해시 충돌을 찾을 때까지 여러 입력값을 대입하여 계산할 경우, 계산 횟수의 기대값은 다음과 같다.
따라서,
비트 해시 함수의 충돌을 발견하기 위해서는 평균적으로
가지의 입력값만 조사하면 되며, 이것은 모든 가능한 가짓수가
인 것에 비교하여 차수를 크게 감소한 것이다.
바깥 고리[편집]
- (영어) "What is a digital signature and what is authentication?" from RSA Security's crypto FAQ.
- (영어) "Birthday Attack" X5 Networks Crypto FAQs


