RSA
RSA היא מערכת הצפנת מפתח ציבורי דטרמיניסטית מעשית הראשונה שהומצאה והיא עדיין בשימוש נרחב במערכות אבטחת מידע מודרניות, תקשורת מחשבים ומסחר אלקטרוני. ב־RSA, כבכל מערכת מפתח ציבורי, מפתח ההצפנה אינו סודי והוא שונה ממפתח הפענוח שנשמר בסוד, על כן היא נקראת אסימטרית. האסימטריה ב־RSA נובעת מהקושי המעשי שבפירוק לגורמים של מספר פריק שהוא כפולה של שני ראשוניים גדולים, שהיא בעיה פתוחה בתורת המספרים. השם RSA נובע מראשי התיבות של שמות המשפחה של הממציאים, רון ריבסט, עדי שמיר ולאונרד אדלמן, שפרסמו את האלגוריתם לראשונה ב־1977. ישנן עדויות שהאלגוריתם היה ידוע עוד קודם לכן לשירותי המודיעין של ארצות הברית ובריטניה ונשמר בסוד מטעמים של ביטחון לאומי.
בתמצית הרעיון הוא; השולח משתמש במפתח ההצפנה הציבורי של הנמען כדי להצפין עבורו מסר כך שרק הנמען מסוגל לפענחו באמצעות המפתח הפרטי המתאים שברשותו. המפתח הציבורי כולל שלם יחד עם המספר הפריק שהוא כפולה של שני ראשוניים גדולים שווים באורכם בקירוב, הנקרא מודולוס. הצפנה היא העלאת המסר בחזקת מודולו ואילו פענוח נעשה על ידי הפעולה ההפוכה אותה הנמען מבצע על ידי העלאת הטקסט המוצפן בחזקת ההופכי הכפלי של שהוא המפתח הסודי (שאותו אפשר לכתוב גם: ) במילים אחרות פענוח שקול להוצאת שורש ממעלה מודולו .
בידיעת הגורמים הראשוניים חישוב המפתח הסודי מתוך המפתח הציבורי הוא מלאכה קלה, כפי שיתואר בהמשך ואילו ללא ידיעת הגורמים הראשוניים אין דרך יעילה לחישובו בזמן סביר. לכן "הקושי" נמדד במספר הפעולות האלמנטריות הנדרש כדי לפרק את המודולוס לגורמים. ההבדל בפקטור העבודה בין העלאה בחזקה מודולרית לבין חישוב שורש מודולרי שהן פעולות הופכיות, הוא המקור לפונקציה החד־כיוונית שבבסיס RSA. שבירת מערכת ההצפנה, דהיינו פענוח המידע ללא ידיעת הגורמים הראשוניים של נקרא בעיית RSA והיא נחשבת לבעיה קשה. אלגוריתם RSA נחשב איטי יחסית ועל כן אינו מתאים להצפנה ישירה של מידע בכמות גדולה. במקום זאת, RSA משמש לשיתוף והעברה של מפתח סימטרי סודי אשר בתורו משמש להצפנה מהירה של המידע עם אלגוריתם סימטרי כמו AES.
RSA שאבה השראה מרעיון המפתח הציבורי שהומצא כשנה קודם לכן על ידי ויטפילד דיפי ומרטין הלמן והוא האלגוריתם האסימטרי הראשון ששימש גם להצפנה וגם לחתימה דיגיטלית. RSA היה לפורץ דרך בתולדות ההצפנה המודרנית והמצאתו העלתה את בעיית פירוק לגורמים לחזית המחקר בתורת המספרים היישומית, שכן ביטחונו מסתמך על כך שלא ניתן לפתור בעיה זו בפרק זמן סביר. אלגוריתם RSA אינו פוסט־קוונטי, כלומר עם המצאת מחשב קוונטי מעשי בקנה מידה גדול, צופן RSA לא יהיה בטוח יותר לשימוש משום שבעיית פירוק לגורמים תהיה קלה לפתרון באמצעות אלגוריתם שור.
היסטוריה
החיסרון העיקרי בצפנים סימטריים הוא שהמפתח הסודי נדרש הן להצפנה והן לפענוח ולכן יש צורך להעבירו לידי השולח בדרך כלשהי ובכך לסכנו בחשיפה. ב־1976 פרסמו ויטפילד דיפי ומרטין הלמן מאמר המתאר את התפיסה של ההצפנה האסימטרית, שבה הנמען מפרסם מפתח הצפנה פומבי בעזרתו מבוצעת הצפנת מסרים הנשלחים אליו, ואילו הפענוח מתבצע אך ורק באמצעות המפתח הפרטי שברשותו, שמעולם לא נחשף. כשנה לאחר מכן ב־1977, רונלד ריבסט, עדי שמיר ולאונרד אדלמן מ־MIT פרסמו לראשונה במגזין סיינטיפיק אמריקן את RSA (שמו נגזר מראשי תיבות שמותיהם), שיישם לראשונה את המודל של דיפי והלמן באופן מעשי. אלגוריתם RSA זיכה את ממציאיו בפרס טיורינג לשנת 2002.
זכויות יוצרים
RSA נרשם כפטנט בארצות הברית בשנת 1983 ותוקפו פג בספטמבר 2000. בדצמבר 1997 פרסם מטה התקשורת של המודיעין הבריטי GCHQ מסמך בו נטען כי רעיון המפתח הפומבי היה ידוע להם כעשור לפני שהתפרסם. הם גילו לטענתם גם את RSA וגם את דיפי־הלמן, אך שמרו את הדבר בסוד. גם ה־NSA טען שגילה את RSA הרבה לפני שנודע לציבור, אולם התגלית סווגה כסוד לאומי. המתמטיקאי הבריטי קליפורד קוקס שעבד בסוכנות הביון הבריטית, פרסם מסמך[1] בו נטען כי ב־1973 המציא אלגוריתם הצפנה דומה ל־RSA. ייתכן שבקהיליית המודיעין המצאות אלו היו ידועות שנים רבות לפני שהציבור התוודע להם. בכל מקרה ספק אם לממצאים אלו הייתה תועלת מעשית כלשהי באותה עת.
הכנה
בגרסת RSA הבסיסית, תחילה להכנה:
- בוחרים שני מספרים ראשוניים גדולים ו־
- מחשבים את
- מחשבים את כאשר נקראת פונקציית אוילר.
- בוחרים שלם שהוא זר ל־
- מחשבים המקיים את הקונגרואנציה:
פירוט הפרמטרים
- ו־ בשלב 1 צריכים להיות ראשוניים גדולים כדי להקשות על פירוק לגורמים ואקראיים כדי להקשות על ניחושם. האסטרטגיה המומלצת היא להגריל מספר אקראי אי־זוגי באורך הרצוי באמצעות מחולל פסידו-אקראי ובדיקת ראשוניותו באמצעות אלגוריתם לבדיקת ראשוניות. אפשר להסתפק באלגוריתם הסתברותי כגון מילר־רבין אם הפרמטרים נבחרו כראוי. משפט המספרים הראשוניים מבטיח שתוך מספר קטן יחסית של הגרלות (בערך כמספר הספרות של המספר), נתקלים בראשוני.
- נקרא מודולוס ומהווה את קבוצת השלמים הטבעיים כאשר פעולות אריתמטיות סגורות תחת , כלומר תוצאת פעולות חיבור וכפל היא השארית מחילוק ב־ (ראו חשבון מודולרי). משמש כמפתח פומבי ונדרש להצפנה ופענוח.
- הוא מפתח פומבי המשמש להצפנה ויכול להיות כל שלם טבעי הנמוך מ־ ובלבד שיהיה זר ל־ כלומר שאין לו מחלק משותף עם מלבד 1. מסמנים זאת: (הפונקציה gcd מציינת מחלק משותף מרבי). זאת כדי להבטיח כי ההצפנה תהיה תמורה ייחודית (כלומר עבור כל מסר מוצפן יהיה מסר מפוענח יחיד המתאים לו). רצוי לבחור קטן ככל האפשר כדי להקל על תהליך ההצפנה.
- הוא מפתח פרטי המשמש לפענוח וצריך להישמר בסוד. הוא הופכי כפלי מודולרי של (מודולו ) וניתן לסמנו: . להכנת אפשר להיעזר באלגוריתם אוקלידס המורחב (להלן)
- הראשוניים ו־ לא נחוצים לתהליך ההצפנה והפענוח על כן רצוי להשמידם.
פרמטרים מתקדמים
- בתקן PKCS (גרסה 2), שונה מעט תהליך הכנת המפתחות. במקום לחשב את מחשבים את , שהוא האקספוננט של חבורת אוילר (הפונקציה היא הכפולה המשותפת המינימלית). במקרה זה צריך לקיים את יחס השקילות .
- תקן PKCS תומך בגרסה מתקדמת הנקראת RSA-CRT בה מנצלים את משפט השאריות הסיני כדי לחלק את מפתח הפענוח הסודי לשני מפתחות קטנים. מחשבים את כך שמתקיים ו־ כאשר ובאופן דומה מחשבים את מקדם CRT שהוא ההופכי הכפלי של מודולו המסומן בקיצור . הראשוניים ומקדם ה־CRT נדרשים להצפנה ופענוח ועל כן יש לשומרם בסוד. כמו כן תהליך הפענוח שונה במעט (להלן).
- התקן תומך גם בגרסת "Multi-prime" שבה מספר הגורמים הראשוניים של המודולוס גדול משניים. במקרה זה, עבור הראשוניים כאשר מחשבים את המעריכים כך שמתקיים וכן הנקראים מקדמי כך שמתקיים כאשר הוא כפולה של כל הראשוניים למעט . בשיטה זו יש לשמור את כל השלישיות . וכן תהליך הפענוח שונה בהתאם (להלן).
הצפנה ופענוח
אליס משדרת לבוב את מפתחות ההצפנה () ושומרת בסוד את המפתח . אם בוב מעוניין לשלוח את המסר לאליס תחילה עליו להפוך את לערך מספרי הנמוך מ־ בדרך מוסכמת כלשהי.
הצפנה
- .
להצפנה בוב פשוט מעלה את בחזקת ונוטל את השארית מחילוק ב־. את הטקסט המוצפן הוא יוכל לשדר לאליס בערוץ פתוח ונגיש לכל.
פענוח
לפענוח אליס משחזרת את המסר מתוך הטקסט המוצפן בעזרת המפתח הסודי בדרך זו:
גרסאות מתקדמות
RSA-CRT
בגרסת CRT המופיעה בתקן, תהליך ההצפנה נותר זהה אך תהליך הפענוח שונה והוא מורכב משלושה שלבים:
- משתמשים במפתחות הפענוח מתהליך ההכנה לעיל, כדי לחשב את וכן .
- מחשבים את כאשר הוא הופכי כפלי מודולרי של מודולו
- התוצאה תהיה
היות שפעולת העלאה בחזקה מודולרית היא הפעולה הארוכה והאיטית ביותר בכל התהליך. היתרון בשיטה זו כאמור שהיא נעשית מודולו ו־ כל אחד בנפרד. היות שהם קטנים מהמודולוס בחצי מושג שיפור בפקטור של 2 בקירוב.
RSA Multi-primes
בגרסת Multi-Prime שבה מספר הגורמים גדול משניים, שוב ההצפנה זהה לגרסה הבסיסית ואילו הפענוח מתבצע כדלהלן:
- תחילה עבור הגורמים כאשר מחשבים את כאשר הם מפתחות הפענוח שהוכנו קודם (פרמטרים מתקדמים לעיל).
- מחשבים את .
- מחשבים את .
- מציבים ועבור עד מחשבים את:
- (כפולת כל הראשוניים למעט )
יש לזכור שכל הפעולות מבוצעות מודולו . מכיוון שהפרמטרים ביישום מעשי בדרך כלל גדולים, חישוב חזקות בסדר גודל כזה נעשה בשיטות לחישובים מודולריים מרובי ספרות (ראה חשבון מודולרי).
השיטה הבסיסית המתוארת כאן אינה בטוחה לשימוש לפי מודל ביטחון מחמיר שנקרא עמידות נגד התקפת מוצפן-נבחר לכן במרבית המקרים אין להשתמש בה כך. תחת זאת, התקן מפרט שיטות להכנה בטוחה של המסר להצפנה באופן כזה שההצפנה תהיה בטוחה ולא תדליף מידע שלא במתכוון (ראו ריפוד). בנוסף, כדי למנוע התקפה אקטיבית על המערכת מצד גורם זדוני שיכול לשנות מסרים בדרכם, רצוי להבטיח את שלמות המפתחות ושייכותם לבעליהם. מקובל לרשום את המפתח הציבורי אצל צד שלישי מהימן כמו רשות אישורים (ראה מפתח פומבי).
בסיס מתמטי
- ערך מורחב – בעיית RSA
ביטחון שיטת RSA מתבסס על בעיית RSA כדלקמן; נתון שלם חיובי , מכפלת שני ראשוניים שונים שווים בגודלם בקירוב, נתון שלם חיובי הנמוך מ־ המקיים (פירושו ש־ זר ל־) ונתון שלם כלשהו. מצא את המקיים את המשוואה: . במילים אחרות הבעיה היא מציאת שורש ממעלה של (מודולו ).
הרעיון מאחורי אלגוריתם הפענוח של RSA מבוסס על משפט אוילר הקובע: עבור כל ו־ טבעיים הזרים זה לזה (שאין להם מחלק משותף מלבד 1) מתקיים: . הפונקציה נקראת פונקציית אוילר ומייצגת את מספר הטבעיים הזרים ל־ וקטנים ממנו. אם מכפילים את שני אגפי השקילות האמורה ב־ מתקבל: .
הוכחת נכונות
לפי האלגוריתם מפתח הפענוח מקיים את השקילות ,
כלומר הוא כפולה כלשהי של שהוא בעצם , בניסוח אחר קיים שלם המקיים לכן הוא פתרון של המשוואה כי עבור כל שלם הנמוך מ־ מתקיים:
|
|
והפתרון הוא יחיד כיוון שאם קיים פתרון אחר נניח שגם הוא פתרון של אז:
|
|
דוגמה במספרים קטנים
נניח שאליס בוחרת את הראשוניים
ומחשבת את:
ואת פונקציית אוילר:
וכן בוחרת את , שים לב שמתקיים כנדרש.
בעזרת אלגוריתם אוקלידס המורחב מתקבל
לכן יהיה מפתח הפענוח המתאים. אליס שולחת את
ואת לבוב ושומרת בסוד את .
אם בוב מעוניין להצפין את המסר עבור אליס הוא מחשב את:
- ושולח את לאליס.
כשאליס מקבלת את היא משחזרת את בעזרת המפתח הסודי:
- .
בגרסת CRT מחשבים תחילה את מפתחות הפענוח כי מתקיים באופן דומה מוצאים את .
ואז לפענוח מחשבים את וכן
מחשבים את ההופכי הכפלי של מודולו שהוא ואז . שים לב שהיות ש־ הוא מספר שלילי לכן לפי הכלל בחשבון מודולרי (מודולו במקרה זה) הוא שקול למעשה ל־.
מה שנותר הוא לחשב את .
הדוגמה היא להמחשה בלבד: חובה על הראשוניים ו־ להיות הרבה יותר גדולים מהדוגמה המובאת כאן, כדי למנוע ניסיון לתקוף את האלגוריתם על ידי פירוק לגורמים באמצעות אלגוריתם פירוק לגורמים ידוע (ראו פירוק לגורמים).
חתימה דיגיטלית
אלגוריתם RSA יכול לשמש גם כחתימה דיגיטלית. כיוון שפונקציית ההצפנה היא התאמה על המפתחות יכולים להחליף תפקידים והחתימה מתבצעת על ידי היפוך סדר ההצפנה והפענוח לעיל. כדי לחתום על המסר אליס מצפינה אותו באמצעות המפתח הסודי שלה ושולחת את התוצאה לבוב, כדי לאמת את החתימה בוב מפענח את המסר באמצעות המפתח הפומבי (של אליס). אולם יש צורך לקודד את המסר באמצעות פונקציית יתירות מוסכמת שאינה סודית לפני החתימה ואת החתימה לבצע על תוצאת הפונקציה, כדלהלן:
אם אליס מעוניינת לשלוח את המסר כשהוא חתום על ידה לבוב, היא מבצעת:
- (בדיוק כמו בתהליך הפענוח לעיל).
כאשר היא פונקציית היתירות האמורה והחתימה היא . שים לב אף על פי שהמטרה בחתימה הדיגיטלית אינה סודיות, כיוון שאליס בעצם הצפינה את המסר היא לא צריכה לשלוח אותו כיוון שבוב מסוגל לשחזרו מתוך החתימה. על כן השיטה המתוארת אפשרית רק כשהמסר קצר (קטן מהמודולוס), כדי לחתום על מסר גדול יותר, נוקטים בשיטה אחרת, תחילה משתמשים בפונקציית גיבוב על המסר ואת החתימה מבצעים על תוצאת פונקציית הגיבוב במקום על המסר עצמו. במקרה זה אליס תצטרך לשלוח גם את המסר עצמו בנפרד.
לאימות החתימה, בוב מחשב את:
- (בדיוק כמו תהליך ההצפנה לעיל)
בוב משיג עותק אותנטי של מפתח האימות של אליס (המקביל למפתח ההצפנה ) באמצעותו מפענח את ובהפעלת הפונקציה ההופכית משחזר את המסר המקורי. בוב יכול להיות משוכנע כי רק אליס שהיא בעלת המפתח הפרטי המתאים, יכולה הייתה להיות המקור למסר ובמיוחד שלא שונה על ידי גורם כלשהו במהלך המשלוח.
פונקציית היתירות הכרחית כיוון שללא השימוש בה יהיה קל למצוא מסר אחר שעבורו החתימה של אליס תהיה תקפה ללא ידיעת המפתח הפרטי שלה. זאת בשל הכיפליות של RSA. כדי לראות מדוע נניח כי (פונקציית הזהות), אם אליס חתמה על שני מסמכים שונים ו־ אזי כפולה של החתימות: ו־ על המסרים הנ"ל תהיה חתימה תקפה עבור המסר . פונקציית היתירות מבטלת את האסוציאטיביות של החתימות ועל כן מונעת בעיה זו.
גרסאות מתקדמות
החסרון העיקרי בגרסה הבסיסית הוא בגודל מפתח הפענוח שחייב להיות מטעמי ביטחון קרוב לגודלו של . היות שאלגוריתם RSA מערב העלאה בחזקה מודולרית, זמן ההצפנה והפענוח תלויים ישירות במספר סיביות המפתחות. מאז המצאת RSA נעשו מספר ניסיונות לצימצום גודל המפתחות ולשפר בכך את יעילות האלגוריתם. הדרך הפופולרית ביותר היא ניצול משפט השאריות הסיני (CRT). הרעיון הוא לפצל את מפתח הפענוח למספר מפתחות קטנים, חישוב העלאה בחזקה עם כל אחד מהם בנפרד ואז שילוב התוצאות בעזרת אלגוריתם CRT מתוך מערכת השקילויות שנוצרת. חישוב CRT זניח יחסית לפעולת העלאה בחזקה מודולרית, על כן שיטה זו משפרת משמעותית את תהליך הפענוח. משפט השאריות הסיני מאפשר פענוח מהיר יותר במיוחד בפלטפורמה מרובת מעבדים, בה ניתן לחשב העלאה בחזקה מודולרית באופן מקבילי.
- RSA-CRT[2]
- ב־1982 פותחה גרסת RSA-CRT בה תהליך הכנת המפתחות והפענוח דורשים מספר התאמות: מחשבים שני מפתחות פענוח ו־ באופן שמתקיים וכן . לפענוח תחילה מחשבים את ואת . נעזרים באלגוריתם של הרווי גארנר לחישוב CRT, כדי לחלץ את מתוך מערכת השקילויות כך: (כאשר הוא הופכי כפלי של מודולו ). המסר יהיה . כיוון שהמפתחות ו־ קטנים בחצי מהמודולוס זמן הפענוח מתקצר בפקטור של 2 כמעט, זאת מבלי לאבד מביטחון האלגוריתם.
- Batch RSA[3]
- גרסת RSA של עמוס פיאט שבה, אם המפתח הפומבי קטן מאוד, ניתן לפענח מספר מסרים שהוצפנו תחת אותו מודולוס בבת אחת. רעיון זה שימושי במערכות דוגמת שרת SSL המבצע פעולות Handshake בתדירות גבוהה. במקרה כזה ניתן לשנות את ארכיטקטורת השרת כך שימתין לקבלת מספר בקשות פענוח ואז יפענח את כל המסרים במחיר של פעולת פענוח אחת, בתנאי שהמודולוס זהה ומפתחות ההצפנה קטנים (ושונים). שיטה זו משפרת את יעילות אלגוריתם RSA בפקטור של כמעט 3.5 אם מבצעים שמונה פענוחים בבת אחת. כדי להסביר כיצד זה פועל, ידוע שבעיית RSA היא מציאת שורש ממעלה כלשהי מודולו שלם פריק . כלומר:
- .
- בתהליכי הפענוח והכנת החתימה המתוארים לעיל, יש צורך להעלות את בחזקת כלומר לחשב את . אם למשל , ונתונים שעבורם צריך לחשב את ואת , אפשר לחשב תחילה את:
- ואת,
- .
- ואז לפתור את המשוואות הנ"ל כדלהלן:
- ,
- .
- יוצא שרק בחישוב נדרשת העלאה בחזקה מודולרית מלאה, בנוסף למספר קבוע קטן של פעולות כפל וחילוק מודולריים. החסכון הוא ששתי העלאות בחזקה מודולו בוצעו כמעט במחיר של העלאה בחזקה מודולרית אחת. הטריק המתואר מסתמך על העובדה שהמעריכים זרים זה לזה. אפשר להוסיף שיפורים לשיטה זו כמו CRT האמור. החסרון העיקרי הוא בצורך במפתחות הצפנה קטנים מאוד. כאשר מפתח הצפנה גדול, Batch RSA לא תהיה יעילה בשל התקורה הרבה הנוספת.
- Multi-prime RSA
- גרסה זו מבוססת על שינוי מבנה המודולוס. מיישמים את RSA עם מודולוס במבנה או כאשר . מכינים מפתחות פענוח מתאימים כמספר הגורמים, מפענחים עם כל מפתח במפרד ואז מחשבים את מערכת הקונגרואנציות באמצעות אלגוריתם CRT. במקרה של שלושה גורמים, אם המודולוס בגודל 2048 סיביות, כל גורם ראשוני יהיה בערך בגודל 683 סיביות. חישוב חזקה מודולרית בסדר גודל כזה מהיר במידה ניכרת מאשר חישוב החזקה עם המודלוס עצמו. משיקולי ביטחון במקרה שהמודולוס בגודל 1024 סיביות מספר הגורמים המקסימלי יכול להיות 3. RSA multi-prime מהירה יותר מהגרסה הבסיסית בפקטור של 2 בקירוב. תקן PKCS #1 תומך בגרסה זו.
- Multi-power RSA
- בגרסה זו המודולוס הוא מהצורה: כאשר ו־ הם בגודל סיביות (n הוא מספר סיביות המודולוס). במקרה של 1024 סיביות משיקולי ביטחון, לכל היותר . בפענוח משתמשים בשיטת למת הנזל (Hensel lifting) שהיא יעילה יותר מהעלאה בחזקה מודולית רגילה. בשיפורים קלים multi-power יעילה יותר מהשיטה הבסיסית בפקטור של 2.3 לפחות.
- Rebalanced RSA
- הרעיון בשיטה זו הוא לפתור את חוסר האיזון הקיים בגרסה הבסיסית של RSA בין גודל מפתח ההצפנה לבין גודל מפתח הפענוח. משיקולי יעילות מפתח ההצפנה בדרך כלל קטן משמעותית. עובדה שלא תמיד רצויה היות שעלול להווצר עומס יתר בצד המפענח לעומת הצד המצפין. במיוחד הדבר חשוב במכשיר נייד שאמור לייצר חתימת RSA שלאחר מכן תאומת על ידי שרת מהיר. כאן דווקא תהליך יצירת החתימה (המקביל לפענוח) צריך להיות קל יותר כיוון שנעשה בסביבה מוגבלת במשאבים. גרסת Rebalanced RSA דומה ל־RSA-CRT המתוארת לעיל, מלבד זאת שבגרסה זו מקזזים מגודל מפתח הפענוח על חשבון מפתח ההצפנה. השוני הוא בעיקר באלגוריתם הכנת המפתחות. אם השיטה מיושמת נכון ניתן להגיע למפתחות פענוח בסדר גודל של 160 סיביות כל אחד (במקרה של מודולוס בגודל 1024 סיביות). התקורה הנוספת מתהליך הכנת המפתחות וכן חישוב CRT בשלב הסופי של הפענוח נמוכה ביותר. חסרונה של השיטה הוא בעיקר בעובדה שהמפתח הפומבי גדול יותר, עקב כך לא בכל המערכות ניתן לישמה. יש מערכות המגבילות את גודל מפתח ההצפנה משיקולי יעילות. שיטה זו יעילה יותר מהגרסה הבסיסית של RSA בפקטור של 3 לפחות.
- Unbalanced RSA
- הצעה של עדי שמיר שבה הגורמים הראשוניים אינם שווים בגודלם (מכאן השם). הרעיון הוא שכדי להקשות על שבירת RSA בדרך של פירוק לגורמים רצוי שהמודולוס יהיה גדול ככל האפשר, אולם זה פוגע ביעילות השיטה במיוחד בסביבה מוגבלת במשאבים. אולם אם קטן, נניח 1000 סיביות ו־ גדול פי חמש, אזי משיגים שיפור בביטחון השיטה ועדיין תהליכי ההצפנה והפענוח נותרים באותה רמת סיבוכיות (בתנאי שהמסר קטן מ־). זאת כיוון שיעילות אלגוריתמים המנצלים קיומם של גורמים קטנים אינה גבוהה והאלגוריתמים הכלליים פחות יעילים כאשר המודולוס גדול. בשיטה זו ההצפנה זהה, כל עוד המעריך גדול מספיק כדי ש־ מספיק גדול. לפענוח מנצלים את CRT כדי לחשב את: כך: תחילה מצמצמים ואת ואז מחשבים את . אך יש להיזהר מפני התקפת מוצפן־נבחר שבה התוקף מצליח לחלץ מידע מסוים לגבי סיביות המפתח, כאשר מנסים לפענח את התוצאה תהיה במקרה זה מתקבלת הודעת שגיאה מהמערכת. באמצעות חישוב CRT וחיפוש בינארי ניתן למקד את החיפוש עד כדי חשיפת המפתח כולו במספר קטן של ניסיונות.
סוגיית ביטחון גרסאות אילו היא שאלה פתוחה. לא ברור לגמרי האם טכניקות אילו מחלישות או מחזקות את ביטחון אלגוריתם RSA. אם כי לא ידוע על דרכים יעילות לשבירת האלגוריתם בשל שינויים אילו. ראו המאמר של דן בונה וחובב שחם Fast Variants of RSA[4] שפורסם במגזין Cryptobytes של RSA, קיץ 2002.
ריפוד
- ערך מורחב – ריפוד אופטימלי להצפנה אסימטרית
הצפנת RSA מכונה דטרמיניסטית משום שהאלגוריתם אינו מערב שימוש במספרים אקראיים בניגוד לשיטות הצפנה הסתברותיות (כמו אל־גמאל). משמעות הדבר היא שבהצפנת אותו מסר פעמים נוספות (עם מפתח הצפנה זהה) תתקבל תמיד תוצאה זהה. הצפנה דטרמיניסטית פגיעה מעצם טבעה להתקפת מוצפן־נבחר, בה מניחים שהתוקף מסוגל לבחור טקסטים אותם הוא מעוניין להצפין ולנתח את תוצאת הצפנתם, אך אין לו גישה למפתח הפענוח עצמו. כתוצאה מכך, ייתכן מצב שהתוקף יוכל לנחש או לחשוף מידע חלקי או מלא אודות הצופן. כמו כן ישנם מקרי קצה שבהם המסר המיועד להצפנה עלול להוות נקודת תורפה כגון אם הוא קטן מאוד או בעל מבנה ייחודי. במקרה כזה הטקסט נקרא "חלש" כי הוא מסכן את ביטחון ההצפנה. למשל:
- כאשר או או תוצאת ההצפנה תהיה תמיד עצמו.
- כאשר מצפינים עם מעריך קטן כגון ערכים קטנים של עלולים להניב תוצאות קטנות הנמוכות מהמודולוס מה שמאפשר חישוב שורש ממעלה שלישית ללא תלות במודולוס.
- כשהמסר קטן ניתן לתקוף את ההצפנה בהתקפת מוצפן־נבחר, שבה התוקף מצפין מראש את כל האפשרויות של ואז בחיפוש קל ימצא את המתאים ובכך יפענח את הטקסט המוצפן מבלי לתקוף את השיטה עצמה.
כדי להימנע ממסר חלש וכדי לסכל התקפת טקסט מוצפן נבחר שמנצלת חולשה זו, מקובל לרפד את המסר באמצעות אלגוריתם ריפוד מוסכם לפני ההצפנה. שיטת הריפוד עצמה לא חייבת להיות סודית. אפשר לשרשר מחרוזת אקראית למסר לפני ההצפנה כך שמבנהו המקורי מיטשטש ובזמן הפענוח פשוט מסירים את המחרוזת האקראית. תקן PKCS #1 יישם שיטת ריפוד פשוטה כזו. לפני ההצפנה המסר רופד באפסים ובמספר אקראי באורך מוגדר כלשהו. ב־1998 הראה דניאל בלייכבכר ממעבדות בל ששיטת ריפוד כזו אינה בטוחה כלל ואפשר לפרוץ אותה בקלות. ב־1995 ניסחו מיהיר בלייר ופיליפ רוגווי את רעיון מודל אורקל אקראי[5] והראו שבאמצעותו אפשר ליישם כל שיטת הצפנה אסימטרית (דטרמיניסטית) באופן שתהיה בעלת ביטחון סמנטי. על בסיס רעיון זה פותח אלגוריתם OAEP המשתמש במחולל מספרים אקראיים בטוח ופונקציית גיבוב קריפטוגרפית בשילוב עם RSA להצפנה בטוחה. ב־1998 תקן הצפנת מפתח־פומבי PKCS #1 תוקן ואלגוריתם OAEP שולב בתקן כשיטת הריפוד התקנית להצפנת מפתח פומבי הנקראת RSA-OAEP (ראה תרשים).
אלגוריתמים
כדי ליישם את RSA במחשב אין די בדרך הרגילה באמצעות יחידת החישוב במעבד, כיוון שאורך מקסימלי של מספר שניתן לעיבוד בדרך קונבנציונלית אינו עולה על גודלו של האוגר הגדול ביותר. ככל שהמחשבים השתפרו, הצורך באריתמטיקה מודולרית במספרים גדולים בהרבה רק הלך וגדל. משום כך הפתרון הוא אריתמטיקה מרובת ספרות (Multi-precision), כלומר חישוב ספרה אחר ספרה בנפרד כאשר כל ספרה תופסת קרוב לאוגר שלם. בדרך זו החישוב יותר איטי, אך אורך המספרים אינו מוגבל (בגבולות הזיכרון הזמין במחשב). קיימות ספריות לחישובים אריתמטיים מרובי ספרות לשפות התכנות הנפוצות כמו FreeLIP לשפת C של ארג'ן לנסטרה, שסייעה באתגר הראשון כנגד RSA, פירוק RSA-129 ב־1994 או המחלקה BigInteger של Java.
מרכיב חשוב בהכנת RSA הוא יצירת מפתח הפענוח שנקרא הופכי כפלי מודולרי של (מודולו ). כדי למצוא מספר כזה צריך לפתור את משוואת אוקלידס עבור שלם כלשהו. אפשר לבצע זאת באמצעות אלגוריתם אוקלידס המורחב. להלן הגרסה הבסיסית:
MultiplicativeInverse(a, b)
{
y1 = 1, y2 = 0;
While (b > 0)
{
q = a/b;
y = y2 –(q * y1);
r = a % b;
a = b, b = r;
y2 = y1, y1 = y;
}
return y2;
}
הצפנה ופענוח דורשים פעולות העלאה בחזקה עם מעריך גדול. הדרך הנאיבית לחישוב חזקה אינה יעילה במקרה זה. קיימים מספר אלגוריתמים לחישוב חזקות גדולות באריתמטיקה מודולרית. להלן תיאור שיטה רקורסיבית בסיסית שנקראת Square and Multiply או "העלאה בחזקה משמאל לימין". הרעיון הוא שאפשר לחשב את באמצעות סדרת הריבועים עד , אפשר להכין סדרה כזו באופן רקורסיבי על ידי העלאות חוזרות בריבוע: . לפי חוקי האריתמטיקה מודולו אפשר לבצע את הצמצום המודולרי לאחר כל העלאה בריבוע במקום לבצע את הצמצום בסוף ובכך להימנע מהתנפחות התוצאה. לפי חוקי החזקות אפשר לקבל את כמכפלה של ערכים מתוך הסדרה האמורה, אותם אפשר לקבל על ידי הייצוג הבינארי של המעריך, דהיינו כאשר הסיבית הנוכחית היא אחד יש לכלול את האיבר המתאים במכפלה. הטבלה הבאה מדגימה את . הפרמטר בטבלה מכיל את הייצוג הבינארי של המעריך: כאשר הסיבית הימנית היא הסיבית הכי פחות משמעותית והסיבית השמאלית היא הסיבית המשמעותית ביותר. התוצאה תהיה מכפלת ערכי בעמודות בהן כלומר
1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | |
---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | 0 | 1 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | |
245 | 8840 | 6579 | 1205 | 8608 | 2258 | 538 | 2808 | 2374 | 5526 | 9942 | 5129 | |
245 | 245 | 4646 | 4646 | 7046 | 1570 | 1570 | 1570 | 1570 | 1570 | 7752 | 9737 |
את החישוב הזה קשה לעשות בדרך הישירה כמו באמצעות מחשבון כי תוצאת הביניים של ההעלאה בחזקה לפני החילוק היא באורך כאלף ספרות עשרוניות שזה מספר ארוך מדי מכדי להכילו במשתנה אחד. להלן פסאודו קוד של האלגוריתם:
Square_and_multiply(a, k, n)
{
b = 1;
while (k > 0)
{
if ((k & 1) == 1)
b = ((b * a) % n);
a = ((a * a) % n);
k >>= 1;
}
return b;
}
המייצג את סיביות המעריך . בלולאה הראשית סורקים את סיביות מימין לשמאל (מהספרה הכי פחות משמעותית לספרה הכי משמעותית), מעלים את בריבוע בכל סבב וכל פעם שהסיבית הנוכחית היא 1 בנוסף מכפילים ב־. התוצאה הסופית נשמרת ב־.
החלק הקשה באלגוריתם הוא הצמצום המודולרי. בשיטה הנאיבית מחלקים חילוק ארוך ב־ ונוטלים את השארית. השימוש בחילוק גוזל זמן עיבור ולכן במספרים גדולים מאוד אינו מומלץ אם רוצים להגיע לביצועים אופטימליים. קיימות שיטות יעילות יותר לצמצום מודולרי כמו שיטת "חלון הזזה" שיטת Barrett ושיטת מונטגומרי. האחרונה נחשבת ליעילה ונפוצה במימושים מעשיים. לשיפור נוסף בביצועים יש המיישמים את פעולות הכפל במספרים הגדולים (מגודל מינימלי שנקבע לפי המערכת) בשיטת קרצובה או טום־קוק בסגנון הפרד ומשול.
התקפות
התקפת ערוץ צדדי
- ערך מורחב – התקפת ערוץ צדדי
Timing Attack היא התקפת ערוץ צדדי שעושה שימוש בעובדה שמהירות ההצפנה תלויה בקלט. אם לתוקף יש גישה למערכת (כמו כרטיס חכם או מעגל משולב במכשיר) שבו מתבצעים ההצפנה והפענוח, אך אין לו גישה למפתח הפענוח עצמו המוטמע במערכת. עדיין ביכולתו לחלץ את המפתח באמצעות מדידת הפרשי הזמן בעת פענוח מספר מסוים של טקסטים מוצפנים. יתרה מזו, אם מיישמים אחת מהגרסאות הממוטבות של RSA שעושה שימוש בגורמים הראשוניים, הדבר עלול להוביל לפרצה מסוימת כיוון שניתן למדוד את המידע שדולף מהמערכת בזמן חישוב מערכת הקונגרואנציות של CRT בגלל התלות בסיביות של המספרים הראשוניים. כמו כן אם ארעה שגיאת חומרה במהלך החישוב וחלק מסיביות הפרמטרים השתבשו עקב כך, יש סכנה שמידע פנימי ידלוף.
ישנן דרכים להתמודד עם זה. למשל להבטיח שתהליך הפענוח יתרחש בזמן קבוע על ידי השהיה מכוונת. אולם בדרך זו יעילות המערכת נפגעת. גישה אחרת הנקראת Blinding מנצלת את תכונת הכפליות של RSA (להלן). במקום לפענח את הטקסט המוצפן ישירות, בוחרים אקראי כלשהו ואז מחשבים את: והתוצאה תהיה . ניתן להסיר את הערך האקראי מהמסר על ידי הכפלה ב־ (ההופכי של מודולו ). בצורה זו הפענוח אינו תלוי בטקסט המוצפן המתקבל ועל כן התקפת תזמון תכשל במקרה כזה. כמו כן יש לוודא תמיד שהודעות השגיאה של המעכת לא יסגירו מידע פנימי, על ידי בדיקה תמידית של תקפות ערכים וכן לוודא שהזמן הדרוש לכל פעולה יהיה קבוע ללא תלות בשגיאה או בנקודת הזמן בו ארעה.
התקפת האדם שבתווך
- ערך מורחב – התקפת אדם בתווך
הצפנת RSA אינה פותרת את בעיית האימות והבטחת השלמות. במילים אחרות, תוקף אקטיבי המסוגל להשתלט על ערוץ התקשורת שבין אליס ובוב יכול בהתקפת אדם באמצע ליירט את מפתח ההצפנה שאליס שולחת לבוב, להחליפו באחר כך שבוב יצפין את כל המסרים עבור אליס במפתח הלא נכון. בדרך דומה מיירט ומשנה את המסרים שבוב שולח לאליס, מפענח את תוכנם, חוזר ומצפינם במפתח המקורי של אליס ושולחם ליעדם. כאשר בוב ואליס אינם מודעים למתרחש. במילים אחרות, בוב חייב להיות בטוח שהמפתח הפומבי שייך לאליס וכן אליס אינה יכולה לדעת מיהו מקור המסר שקיבלה ללא אמצעים נוספים כדי להבטיח זאת. הבטחת שלמות ואותנטיות מפתחות ההצפנה והמסרים נעשים בפרוטוקלים שונים חלקם נעזרים בצד־שלישי נאמן (כמו רשות אישורים CA) וחתימה דיגיטלית.
ראו גם
קישורים חיצוניים
- המאמר המקורי של ריבסט, שמיר ואדלמן A Method for Obtaining Digital Signatures and Public-Key Cryptosystems, המכון הטכנולוגי של מסצ'וסטס, קיימברידג' מסצ'וסטס, אפריל 1977.
- תקן PKCS #1 להצפנת RSA, אתר מעבדות RSA.
- נימוקי הוועדה, להענקת פרס טיורינג ל־RSA
- תמי לפידות וד"ר דלית לוי, הסבר תמציתי ובהיר (עברית) על שיטת RSA, הצפנה בכלל, ומקבלי פרס טיורינג
- סדרת מאמרים של מעבדות RSA, המסבירים את עקרונות אלגוריתם RSA, הבסיס המתמטי, היתרונות והתועלת שבשיטה.
- נצה מובשוביץ־הדר, הרצאה על מספרים ראשוניים והצפנה, יסודות ה־RSA
- התקפות על צופן הRSA במיזם UnderWarrior
- גרסאות מהירות של RSA, מגזין CryptoBytes (כרך 5) ינואר 2002.
הערות שוליים
- ^ Cocks' November 1973 internal GCHQ note on his discovery
- ^ J-J. Quisquater and C. Couvreur. Fast decipherment algorithm for RSA public-key cryptosystem. Electronic Letters, vol 18:905–907, 1982
- ^ עמוס פיאט, אוניברסיטת תל אביב, אפריל 1996
- ^ Fast Variants of RSA (survey)
- ^ M. Bellare and P. Rogaway. "Optimal Asymmetric Encryption" In A. De Santis, ed, Proceedings of Eurocrypt ‘94 vol. 950 of Lecture Notes in Computer Science (LNCS), pp. 92–111. Springer-Verlag,1994.