RSA를 이해해 보자
RSA
비대칭 키 알고리즘이며 이 이름은 알고리즘을 개발한 세 명의 이름을 딴 것. (Rivest–Shamir–Adleman) 왜 안 사전순 ?
https 나 공인인증서 등에 사용된다.
필요한 산수
phi function 일반식 :
means that the product is over all prime divisors of n.
대략의 해석 : n 의 약수인 소수 p 에 대한 모든 f(p) 곱
키 생성
- 서로 다른 소수 p, q 생성
- n = pq 계산
- φ(n) 계산 : [4]
- e 찾기, 1 < e < φ(n) and gcd(e, φ(n)) = 1
- d 계산, ed ≡ 1 (mod φ(n)) d 는 모듈러 φ(n) 의 modular multiplicative inverse 이 값은 Extended Euclidean algorithm 으로 계산 가능, [3]을 이용해도 간단히 구해짐
(n, d) 는 private key, (n, e) 는 public key 가 된다.
이것 외 나머지 모든 값들은 버린다.
암호화 복호화 원리
메세지 m 을 e 로 암호화하여 c 를 얻어냄
c 에서 d 를 사용하여 원문을 계산함
식의 모양을 보면 알 수 있듯, 지수 연산의 교환법칙이 성립하므로, d로 암호화한 것을 e로 풀 수 있다.
그래서 비대칭 암호화 !
증명
다음을 증명하고자 함
ed ≡ 1 (mod φ(n)) 이므로
ed ≡ 1 + h φ(n), h 는 음이 아닌 정수
오일러의 정리에 의해
참고 : 오일러의 정리 요약
양의 정수 𝑛과 정수 𝑎에 관해, gcd(𝑎,𝑛)=1이면 다음이 성립한다.
Written on October 31, 2019