로그인하고 있지 않습니다. 편집하면 당신의 IP 주소가 공개적으로 기록됩니다. 계정을 만들고 로그인하면 편집 시 사용자 이름만 보이며, 위키 이용에 여러 가지 편의가 주어집니다.스팸 방지 검사입니다. 이것을 입력하지 마세요!=== 유클리드 호제법 === <math>\phi\left(n\right)</math>도 찾았고 공개키로 쓸 <math>e</math>도 정했다고 가정하자. 문제는 개인키인 <math>d</math>를 찾는 과정이다. <math>d</math>는 <math>de\equiv1\pmod{\phi\left(n\right)}</math>를 만족해야 하는데, 수학적 직관이 있는 사람이 있는 사람이라면 저 [[합동식]]의 해가 존재하는지 의문을 가질 것이다. 일차 합동식 <math>ax\equiv b\pmod n</math>은 <math>\gcd\left(a,n\right)\mid b</math>여야 해가 존재하므로, 저 합동식의 해가 존재하려면 <math>\gcd\left(e,\phi\left(n\right)\right)\mid1</math>이어야 한다. 이를 만족하려면 <math>\gcd\left(e,\phi\left(n\right)\right)=1</math>이어야만 하고, 이는 <math>e</math>를 <math>\phi\left(n\right)</math>과 서로소인 수를 골라야하는 이유가 된다. 물론 <math>e=1</math>이어도 조건은 만족하지만, 이러면 평서문과 암호문이 똑같아져서 암호화하는 이유가 없어진다(...). 가장 대중적으로 쓰이는 <math>e</math>값은 65537이며,<ref>16진법으로는 010001</ref> 이 수는 [[소수]]<ref>그냥 소수가 아니라 [[메르센 소수]]라는 특별한 소수이다.</ref>이므로 <math>\phi\left(n\right)</math>의 값에 상관없이 쓸 수 있다는 장점이 있다. 사실 RSA 기본 설정에서 공개키는 저 값으로 되어 있고, 특별한 이유가 없으면 바꾸지 말라고 권고하고 있다. [[구글]]을 비롯한 많은 웹 사이트가 저 값을 공개키로 사용하고 있으니 관심있으면 직접 체크해보자. 이제 <math>d</math>가 존재할 수 있음을 알았다. 그럼 이 값을 어떻게 찾을까? 바로 {{ㅊ|이 문단의 이름이기도 한}} [[유클리드 호제법]]을 응용한다. 전 문단에서 유클리드 호제법을 이용해서 최대공약수를 구한다고 했는데, 거기서 조금 더 나아가면 <math>d</math>를 찾을 수 있다. 일단 유클리드 호제법이 뭔지 알아보자. :두 정수 <math>a,b</math>(<math>a> b</math>)에 대해, <math>b=aq+r</math>(<math>0\leq r< b</math>)이라 하면, <math>\gcd\left(a,b\right)=\gcd\left(a,r\right)</math>. :위 연산을 계속 반복하여 <math>r</math>에 해당하는 값이 0이 되면, 그 바로 전 단계의 나머지가 최대공약수가 된다. 자세한 예시를 통해 확인해보자. :23과 7의 최대공약수를 찾고 싶다고 하자. 위 알고리즘을 반복 적용하면, :<math>\begin{align*}23&=7\times3+2\\7&=2\times3+1\\2&=1\times2+0\end{align*}</math> :이 되고, 마지막 단계 바로 전의 나머지가 1이므로 두 수의 최대공약수는 1이다. 이제 여기서 조금 더 나아가 <math>7x\equiv1\pmod{23}</math>을 만족하는 <math>x</math>를 찾아보자. :우선 저 합동식은 <math>7x+23y=1</math>과 동치이다. 한편, 유클리드 호제법에서, :<math>1=7-2\times3=7-3\times(23-7\times3)=7-3\times23+9\times7=10\times7-3\times23</math> :이므로, <math>x=10</math>이다. 뭔가 복잡해보이지만, 유클리드 호제법으로 튀어나온 나머지를 재귀적으로 계속 거꾸로 대입해서 <math>\gcd\left(a,b\right)=ax+by</math>의 형태로 바꾸는 것 뿐이다. 즉, RSA의 경우에는 이 방법을 이용해 <math>ed+\phi\left(n\right)k=1</math>를 만족하는 <math>d</math>를 찾을 수 있고, 그 값이 개인키가 된다. 요약: 리브레 위키에서의 모든 기여는 크리에이티브 커먼즈 저작자표시-동일조건변경허락 3.0 라이선스로 배포됩니다(자세한 내용에 대해서는 리브레 위키:저작권 문서를 읽어주세요). 만약 여기에 동의하지 않는다면 문서를 저장하지 말아 주세요. 글이 직접 작성되었거나 호환되는 라이선스인지 확인해주세요. 리그베다 위키, 나무위키, 오리위키, 구스위키, 디시위키 및 CCL 미적용 사이트 등에서 글을 가져오실 때는 본인이 문서의 유일한 기여자여야 하고, 만약 본인이 문서의 유일한 기여자라는 증거가 없다면 그 문서는 불시에 삭제될 수 있습니다. 취소 편집 도움말 (새 창에서 열림) | () [] [[]] {{}} {{{}}} · <!-- --> · [[분류:]] · [[파일:]] · [[미디어:]] · #넘겨주기 [[]] · {{ㅊ|}} · <onlyinclude></onlyinclude> · <includeonly></includeonly> · <noinclude></noinclude> · <br /> · <ref></ref> · {{각주}} · {|class="wikitable" · |- · rowspan=""| · colspan=""| · |} {{lang|}} · {{llang||}} · {{인용문|}} · {{인용문2|}} · {{유튜브|}} · {{다음팟|}} · {{니코|}} · {{토막글}} {{삭제|}} · {{특정판삭제|}}(이유를 적지 않을 경우 기각될 가능성이 높습니다. 반드시 이유를 적어주세요.) {{#expr:}} · {{#if:}} · {{#ifeq:}} · {{#iferror:}} · {{#ifexist:}} · {{#switch:}} · {{#time:}} · {{#timel:}} · {{#titleparts:}} __NOTOC__ · __FORCETOC__ · __TOC__ · {{PAGENAME}} · {{SITENAME}} · {{localurl:}} · {{fullurl:}} · {{ns:}} –(대시) ‘’(작은따옴표) “”(큰따옴표) ·(가운뎃점) …(말줄임표) ‽(물음느낌표) 〈〉(홑화살괄호) 《》(겹화살괄호) ± − × ÷ ≈ ≠ ∓ ≤ ≥ ∞ ¬ ¹ ² ³ ⁿ ¼ ½ ¾ § € £ ₩ ¥ ¢ † ‡ • ← → ↔ ‰ °C µ(마이크로) Å °(도) ′(분) ″(초) Α α Β β Γ γ Δ δ Ε ε Ζ ζ Η η Θ θ Ι ι Κ κ Λ λ Μ μ(뮤) Ν ν Ξ ξ Ο ο Π π Ρ ρ Σ σ ς Τ τ Υ υ Φ φ Χ χ Ψ ψ Ω ω · Ά ά Έ έ Ή ή Ί ί Ό ό Ύ ύ Ώ ώ · Ϊ ϊ Ϋ ϋ · ΐ ΰ Æ æ Đ(D with stroke) đ Ð(eth) ð ı Ł ł Ø ø Œ œ ß Þ þ · Á á Ć ć É é Í í Ĺ ĺ Ḿ ḿ Ń ń Ó ó Ŕ ŕ Ś ś Ú ú Ý ý Ź ź · À à È è Ì ì Ǹ ǹ Ò ò Ù ù · İ Ż ż ·  â Ĉ ĉ Ê ê Ĝ ĝ Ĥ ĥ Î î Ĵ ĵ Ô ô Ŝ ŝ Û û · Ä ä Ë ë Ï ï Ö ö Ü ü Ÿ ÿ · ǘ ǜ ǚ ǖ · caron/háček: Ǎ ǎ Č č Ď ď Ě ě Ǐ ǐ Ľ ľ Ň ň Ǒ ǒ Ř ř Š š Ť ť Ǔ ǔ Ž ž · breve: Ă ă Ğ ğ Ŏ ŏ Ŭ ŭ · Ā ā Ē ē Ī ī Ō ō Ū ū · à ã Ñ ñ Õ õ · Å å Ů ů · Ą ą Ę ę · Ç ç Ş ş Ţ ţ · Ő ő Ű ű · Ș ș Ț ț