הצפנת פליאיי

מתוך ויקיפדיה, האנציקלופדיה החופשית
(הופנה מהדף הצפנת פאיי)
קפיצה לניווט קפיצה לחיפוש

הצפנת פֵּלִיאֵיאנגלית: Paillier Encryption)[1] היא סכימת הצפנה אסימטרית הסתברותית הומומורפית וחתימה דיגיטלית שהומצאה ב-1999 על ידי פסקל פליאיי (Pascal Paillier) לשעבר מחברת GEMPLUS לוקסמבורג. הצפנת פליאיי הומצאה בהשראת סכימות הצפנה הסתברותית כמו בלום גולדווסר והיא מבוססת על פונקציה חד-כיוונית עם דלת צונחת שנגזרת מבעיה בתורת המספרים הנקראת בעיית השאריות הפריקות (Composite Residuosity Class Problem) מודולו כאשר מכונה "מספר RSA" (כפולה של שני ראשוניים שונים שווים בגודלם בקירוב).

רקע מתמטי[עריכת קוד מקור | עריכה]

הבסיס התאורטי של המערכת הוא, בהינתן שלם כאשר ו- ראשוניים גדולים, שווים באורכם בקירוב והחבורה , השלם ייקרא שארית -ית (ממעלה ) מודולו אם קיים שלם המקיים

.

קבוצת השאריות ה--יות היא תת-חבורה כפלית . לכל כזה קיימים בדיוק שורשים ממעלה . בעיית ההכרעה האם שלם נתון הוא שארית -ית או לא, המסומנת בקיצור (קיצור של Composite Residuosity) נחשבת לבעיה קשה ולא ידוע על אלגוריתם יעיל שיכול לבצעה בזמן פולינומי. סדר החבורה הוא כאשר היא פונקציית אוילר של .

הפונקציה המוגדרת על ידי

עבור ו- היא פונקציה חד-חד-ערכית ועל מעל החבורה ביחס לבסיס נתון. הוא אלמנט מסדר עבור מחלק כלשהו של . הקבוצה היא קבוצת כל האלמנטים מסדר עבור (לדוגמה אפשר לבחור כש-).

אפשר לראות שהפונקציה הפיכה. כדי להפוך את הפונקציה מגדירים את שהיא פונקציה מעל תת-חבורה כפלית של השלמים מודולו המקיימים . שחזור הערכים מתוך מתבצע על ידי

במקום של אפשר לעבוד עם פונקציית קרמייקל שהיא . זהו האקספוננט של חבורת אוילר ו- היא כפולה משותפת מינימלית. שים לב שלפי משפט קרמייקל עבור כל אלמנט מתקיים וכן . בהמשך ייעשה שימוש ב- בכל המקומות בהן הופיעה פונקציית אוילר.

דלת המלכודת היא הגורמים הראשוניים או . כאשר הגורמים הראשוניים של לא ידועים שחזור מתוך ואפילו להכריע האם ללא נחשבים לבעיה קשה תחת המודל הסטנדרטי של סיבוכיות חישובית, בהנחה שפירוק לגורמים של אינו מעשי. האחרונה נקראת בעיית הכרעה של השאריות הפריקות ומסומנת בקיצור DCRA.

סכימות הצפנה וחתימה דיגיטלית[עריכת קוד מקור | עריכה]

על בסיס הרעיון האמור הצפנת פליאיי פועלת כדלהלן. יהי ויהי , אפשר למצוא ערך כזה על ידי בדיקה אם

. הפונקציה מייצגת מחלק משותף מקסימלי.

הערכים ו- יהיו מפתחות ציבוריים ואילו ו- יהיו המפתחות הפרטיים (במקום המספרים הראשוניים אפשר לשמור את ). בהינתן מסר הנמוך מ- להצפנה בוחרים שלם אקראי ומבצעים:

לפענוח:

או מודולו . הסכימה נחשבת הסתברותית בגלל והיא בטוחה סמנטית כנגד יריב פסיבי, בהנחה שבעיית היא בעיה קשה ושקשה לפרק את לגורמים. סיבוכיות ההצפנה היא מסדר גודל של בקירוב.

דוגמה במספרים קטנים[עריכת קוד מקור | עריכה]

לצורך המחשה הראשוניים יהיו , . לכן ו-. הערך . הבסיס נקבע ל-.

מפתח ציבורי: .
מפתח פרטי: .

לצורך הצפנת המסר בוחרים מספר אקראי נניח ואז מחשבים את .

הטקסט המוצפן הוא אם כן .

לפענוח תחילה מחשבים את וכן .

ההופכי הכפלי של מודולו הוא לכן .

פרמוטציה חד-כיוונית עם דלת מלכודת[עריכת קוד מקור | עריכה]

להלן סכימה לא הסתברותית המבוססת חלקית על RSA שנקראת פרמוטציה חד כיוונית עם דלת מלכודת כאשר דלת המלכודת היא . והיא מסתמכת על בעיית בהנחה שפירוק לגורמים של היא בעיה קשה. למרות התלות ב-RSA הסכימה ראויה לציון בשל העובדה שפרמוטציות חד כיווניות עם דלת מלכודת (דוגמת RSA ורבין) הן אובייקטים נדירים וחשובים בקריפטוגרפיה מודרנית.

להצפנה:

תחילה מפצלים את המסר המיועד להצפנה בדרך הפיכה כלשהי לשני חלקים . למשל .
מחשבים את

לפענוח:

תחילה
מחשבים את ערך הביניים
ואז המסר הוא .

אפשר להשתמש בכל תמורה פומבית מוסכמת שממפה את לערכים . יש לשים לב שהסכימה הזו אינה הסתברותית, כלומר אינה מערבת שימוש במספר אקראי.

חתימה דיגיטלית[עריכת קוד מקור | עריכה]

לצורך חתימה דיגיטלית תהי פונקציית גיבוב קריפטוגרפית של המסר שתסומן בקיצור . עבור המסר החותם מחשב את החתימה כדלהלן:

מקבל החתימה יכול לוודא את תקפותה על ידי הבדיקה שמתקיים

הצפנה מהירה[עריכת קוד מקור | עריכה]

סכימות כמו RSA סובלות מחסרון בכך שהפענוח דורש זמן ואינו יעיל במונחי מחשוב. מסיבה זו מערכת הצפנה אסימטרית תהיה אטרקטיבית אם הפענוח יהיה מסדר גודל כמעט ריבועי ביחס ל-. להלן גרסה שונה מעט שבה סיבוכיות הפענוח היא בסדר גודל של עבור קטן כלשהו. הרעיון הוא להגביל את מרחב הטקסט המוצפן לתת קבוצה מסדר נמוך יותר. מסיבות של ביטחון צריך להיות כפולה של ראשוני גדול. בהינתן הבסיס עבור כלשהו, הסכימה היא כדלהלן.

הצפנה:

בוחרים אלמנט אקראי הנמוך מ-.
מחשבים את

פענוח:

הפעם דלת המלכודת מסתמכת על ידיעת כמפתח סודי במקום . צוואר הבקבוק בפעולת הפענוח הוא הפעולה שסיבוכיותה היא בסדר גודל בלבד. אם נבחר באופן כזה ש- אז כל תהליך הפענוח יתבצע עם פעולות בסיביות. זהו מאפיין חשוב בהשוואה למערכת אסימטריות אחרות. אולם יש לשים לב שבמקרה זה המערכת לא מסתמכת על בעיית כיוון שכעת ידוע שהטקסט המוצפן שייך לקבוצה . הבעיה האחרונה, דהיינו לחשב את בהינתן נקראת בעיית הלוגריתם הבדיד 'חלקית' וגם היא משוערת כבעיה קשה.

ביטחון[עריכת קוד מקור | עריכה]

הסכמות המתוארות הוכחו בטוחות מהיבט תאורטי תחת ההנחות הסטנדרטיות, אך לא הוכחו כבטוחות כנגד התקפת מוצפן-נבחר. כדי להבטיח עמידות כנגד התקפות מוצפן נבחר יש לבצע שינויים נוספים. אפשר להגיע לביטחון כזה לפחות תחת מודל אורקל אקראי.

יעילות[עריכת קוד מקור | עריכה]

לפי ההמלצות המקובלות הראשוניים ו- צריכים להיבחר באופן שיהיה קשה לפרק את לגורמים. הבסיס יכול להיבחר באקראי (בגרסה המהירה יידרש טיפול שונה למשל להעלות אלמנט בחזקת ). כדי לשפר ביצועים אפשר לאמץ את שיטת CRT כמו ב-RSA, כלומר כל החישובים יתבצעו מודולו ו- בהתאמה והתוצאה הסופית תהיה חישוב מערכת המשוואות המודולריות המתקבלת באמצעות משפט השאריות הסיני שהוא זניח יחסית לפעולה של העלאה בחזקה מודולרית. אם בוחרים קטן (כמו ) כל עוד הוא מקיים את ההגדרות של הסכימה, יתקבל שיפור נוסף בביצועים בסדר גודל של . יתרה מזו יכול להיות קבוע מה שמאפשר חישוב מוקדם כדי להאיץ ביצועים. בכללות כל הערכים הקבועים וכן חישוב או יכולים להתבצע מראש. בפענוח חישוב הפונקציה ניתן לביצוע במחיר פעולת כפל אחת מודולו על ידי חישוב מוקדם של הקבוע . הקבועים או בגרסה המהירה ניתנים לחישוב מראש.

כדי לנצל את משפט השאריות הסיני (CRT) לשיפור ביצועים, יש להגדיר את הפונקציות ו- כדלהלן: וכן בהתאמה. פענוח יתבצע כעת עם הקבועים הבאים אותם מחשבים מראש:

ואז תהליך הפענוח הוא כדלהלן:

כאשר CRT היא מימוש של פתרון מערכת הקונגרואנציות לפי משפט השאריות הסיני. ובגרסה המהירה יש להחליף את ו- ב-.

מאפיינים והרחבות[עריכת קוד מקור | עריכה]

הצפנת פליאיי הורחבה למספר כיוונים[2]. איוון דמגרד הציע[3] גרסה שבה המודולוס הוא מהצורה במקום בחזקת 2. וכן הוצעה גרסה מבוזרת (סכמת סף - threshold cryptography) וכן הוצע מימוש ב-ECC[4].

הומומורפיזם[עריכת קוד מקור | עריכה]

סכימות ההצפנת פליאיי וכן , מודולו הן הומומורפיות מהחבורה הכפלית לחבורה החיבורית . בניסוח פורמלי עבור כל ו-, פונקציית הצפנה ופונקציית פענוח בהתאמה, מתקיים

וכן הלאה. ההשלכה של מאפיין זה היא שהסכימה תהיה שימושית עבור מגוון פרוטוקולים קריפטוגרפיים כמו הצבעה ממוחשבת, סכימת סף, חלוקת סוד ומנגנון הגנת העתקה (copy protection).

הסתרה עצמית[עריכת קוד מקור | עריכה]

הסתרה עצמית (self blinding) היא התכונה שכל טקסט מוצפן ניתן לשינוי לטקסט מוצפן אחר מבלי שהשינוי ישפיע על הטקסט המקורי, בניסוח פורמלי עבור כל ו- מתקיים

או
במקרה של ההצפנה המהירה.

בעיקרון התכונה הזו מאפשרת לבצע פעולות חישוב על ידי צד שלישי מבלי שהוא עצמו ידע מהו תוכן המידע עליו בוצעו החישובים. לתכונה שימושים רבים בקריפטוגרפיה למשל חתימה עיוורת או מחשוב ענן.

הערות שוליים[עריכת קוד מקור | עריכה]

  1. ^ Public-Key Cryptosystems Based on Composite Degree Residuosity Classes
  2. ^ Catalano, Dario, Rosario Gennaro, Nick Howgrave-Graham, and Phong Q. Nguyen (2001). “Paillier’s cryptosystem revisited.” Proceedings of the 8th ACM conference on Computer and Communications Security ACM Press, New York, 206–214
  3. ^ Damgard, Ivan and Mads Jurik (2001). “A generalization, a simplification and some applications of paillier’s probabilistic public-key system.” Public Key Cryptography—PKC 2001, Lecture Notes in Computer Science, vol. 1992, ed. K. Kim. Springer-Verlag, Berlin, 119–136.
  4. ^ Galbraith, Steven D. (2002). “Elliptic curve paillier schemes.” Journal of Cryptology, 15 (2), 129–138.