انتقل إلى المحتوى

خوارزمية آر إس إيه

من ويكيبيديا، الموسوعة الحرة
(بالتحويل من RSA)
خوارزمية رافيست وشامير وأدلمن
Rivest–Shamir–Adleman
معلومات عامة
المطورون ليونارد أدليمان وآدي شامير ورونالد ريفست
تاريخ النشر 1977
معلومات التعمية
مقاس المفتاح [الإنجليزية] 2,048 أو 4,096 بت

في علم التعمية، آر إس إيه (بالإنجليزية: RSA)‏ هي خوارزمية تعمية بمفتاح عام.[1][2][3] ولعلها الأولى المعروفةً على هذا الصعيد. هي مناسبة للتّوقيع بالإضافة إلى التعمية. كانت أحد التقدّمات العظيمة الأولى في التعمية بواسطة مفتاح عامّ. آر إس إيه مستخدم في بروتوكولات التّجارة الإلكترونيّة على نطاق واسع، وهي آمنة طالما كان طول المفتاح طويلا جدا مثل: 1024 بت. تعتمد بشكل كبير على أنَّه لا توجد خوارزمية لتحليل عدد لعوامل بسرعة عالية.

آر إس إيه هي نسبيا خوارزمية بطيئة. لهذا السبب، لا تستعمل عادة من أجل تعمية كمية كبيرة من البيانات، بل تستعمل من أجل تعمية المفاتيح المستعملة في خوارزمية أخرى ثم تبادلها، كالخوارزميات ذات المفاتيح المتناظرة. بعدئذ، تستعمل الخوارزميات ذات المفاتيح المتناظرة من أجل تعمية كمية كبيرة من البيانات.

تاريخ الخوارزمية

[عدل]

وُصِفَتْ الخوارزمية علناً في عام 1977 من قبل ليونارد أدليمان وآدي شامير ورونالد ريفست في معهد ماساتشوستس للتقنية، الأحرف آر إس إيه هي الحروف الأولى من اسمائهم. وَصفَ كليفورد كوكس، عالم رياضيّات بريطانيّ يعمل مع جي سي إتش كيو (GCHQ) وكالة مخابرات المملكة المتّحدة، نظاماً مكافئاً في وثيقةِ داخليةِ في عام 1973. لكنّه نظرا لغلاء الحواسيب نسبيا الضرورية لتنفيذ هذا النظام في ذاك الوقت، تم اعتبار هذا النظام وكأنه فضول فقط، فلهذا لم يُنْشَر أبدًا. لكنّ اكتشافه لم يُكْشَف حتّى 1997 بسبب تصنيفه السّرّيّ للغاية، وريفيست وشامير وأدليمان ورثوا أو أكملوا آر إس إيه (RSA) عن شغل كليفورد كوكس.

مُنِحَ معهد مساشوستس للتكنولوجيا براءة اختراع ل«نظام وطريقة اتصالاتِ مشفّرةِ» الذي استعملت الخوارزميةَ في عام 1983. انتهت صلاحية براءة الاختراع في 21 سبتمبر 2000. ولأنه تم نشر ورقة تصف الخوارزميةَ في أغسطس 1977، قبل ديسمبر 1977 (وهو تاريخ تقديم الطلب لبرائة الاختراع)، أعاقت القوانين في مُعظم بقيّة العالمِ براءاتَ الاختراع في مكان آخر وبراءة الاختراع الأمريكيّة فقط هي التي كانت تمنح.

إنتاج المفاتيح

[عدل]

تَتضمّنُ خوارزمية آر إس إيه مفتاحا عامّا ومفتاحا خاصّا. المفتاح العامّ هو مفتاح التعمية فقط ويجب أن يكون معلوما لكل من يحاول الاتصال بمالك المفتاح. كما يدل على ذلك اسمه، هو مفتاح عام. لابأس في أن يعلمه جميع الناس. يمكن أن تُفَكّ الرسائل المشفّرة بالمفتاح العامّ فقط باستخدام المفتاح الخاصّ. كما يدل على ذلك اسمه، هو مفتاح خاص. لا ينبغي أن يعلمه أحد. المفاتيح لقاعدة آر إس إيه تُولد بالطريقة التالية:

  1. اختيار عددين أوَلييّن عشوائييّن كبيرين مختلفين و .
  2. حساب . يُسْتَخْدَم معاملا لكلا المفتاحين الخاصّ والعامّ.
  3. حساب .حيث أنَّ الدالة تعطي عدد الأعداد التي بين 2 و n والتي هي أولية مع n أي أنه حيث . تسمى هذه الدالة مؤشر أويلر.
  4. اختيار عدد صحيح بشكل عشوائي حيث و (أَي أَنَّ العددين و- (يعني أنَّ ) أوليين فيما بينهما). هذا العدد سوف يكون الأُس العمومي.
  5. ايجاد قيمة d أو المفتاح الخصوصي، بحيث أنَّه يُحقق التالي: , ويمكن حساب المعادلة الاخيرة بواسطة خوارزمية اقليدس المُوسعة. d سوف يكون الأُس الخصوصي.

المفتاح العمومي يتكوّن من المعامل n والأُس العمومي encryption) e)

المفتاح الخصوصي يتكوّن من المعامل n والأُس الخصوصي decryption) d), والذي يجب أن يكون سريا للحفاظ على امان الخوارزمية.

تعمية الرسائلِ

[عدل]

لنفرض أن A وB يريدان أن يتواصلا فيما بينهما. لنفرض أَنَّ مفتاح A العمومي هو أما المفتاح الخصوصي هو ومفتاح B العمومي هو والمفتاح الخصوصي .

لنفرض أنَّ A يريد أن يرسل رسالة إلى B , لذا عليه فعل التالي:

  1. يحصل على المفتاح العام للمستقبل B والذي هو .
  2. وجد ناتج التعمية لهذا الرقم عن طريق المعادلة
  3. يُرسِل c إلى B.
ملاحظة:
  • إذا كانت الرسالة مكتوبة بالحروف حينها يجب أولا تحويلها لشكل مناسب حيث يتوافق مع العمليات الحسابية ويمكن أن يتم هذا بتحويل الرسالة إلى نظام أسكي.

فك تعمية الرسائلِ

[عدل]

ليحصل B على الرسالة يفعل التالي:

يستخدم مفتاحه الخاص ويحسب . حينها m هي الرسالة التي بعث بها A

صحة الخوارزمية

[عدل]

في كل نظام تعمية أهم خصلة يجب ان تتوفر فيه أنَّه يحقق الصفة التالية: أي أنَّه إذا شفرنا رسالة ثم فككنا التعمية نحصل على نفس الرسالة. وهذا أيضا صحيح ل-RSA : وفك التعمية هو:

مثال

[عدل]
  1. اختيار اثنين من الاعداد الأولية:
  2. حساب أي نفذ التالي
  3. حساب حيث أنَّ هو مؤشر أويلر. .
  4. اختيار الذي ليس له أي عامل مشترك مع , مثل .
  5. نختار d بحيث: , مثلا نختار: d = 2753 وهو ملائم لانه:

المفتاح العمومي هو (n= 3233, e= 17). لذا فإنَّ التعمية كالتالي:

المفتاح الخصوصي هو (n=3233, d=2753)، لذا فإنَّ فك التعمية كالتالي:

لنفرض انَّه يُراد تعمية m = 123، وهذا يكون كالتالي:

وفك تعمية c = 855، يكون ب- .

خوارزميات مُساعدة

[عدل]

الرفع بواسطة التربيع المتكرر

[عدل]

فليكن a,k,n اعداد صحيحة عندها يمكن حساب والتعقيد الحسابي للخوارزمية هو: والخوارزمية كالتالي:

int exp_mod(a,k,n)
{
   int d=1;
   int aa=a;
   while(k>0)
   {
      if(k%2==1)
      {
         d=(d*a)%n;
      }
      k=(k-k%2)/2;
      aa=(aa*aa) %n;
   }
}

صحة هذه الخوارزمية تعتمد على أنّه يمكن كتابة كل عدد k بواسطة النظام الثنائي أي أنَّه: حينها كل ما علينا هو حساب

مثال: نريد أن نحسب:

  1. نحسب 134 بالنظام الثنائي: وهو
  2. نحسب لكل بطريقة التربيع المتكرر أي:

3. حينها y يكون حاصل ضرب كالتالي:

حساب مقلوب عدد

[عدل]

في خوارزمية RSA أردنا أن نجد بحيث يتحقق: لذا فإنه علينا أن نجد: لذا سوف نستخدم خوارزمية اقليدس المُوسعة والسبب هو: بما أنَّ حينها يمكن ايجاد عددين صحيحين a,b بحيث , لذا فان العدد a سوف يكون d . الخوارزمية تعقيدها: .

امان الخوارزمية

[عدل]
  • أيسر الوسائل لخرق امان الخوارزمية هي ايجاد عوامل العدد n , لنقل انه يمكن ايجاد عوامل n بالإضافة لنفرض أنَّ حينها وبما أنَّ المفتاح العمومي موجود ولنفرض أنّه لنجد المفتاح الخصوصي d :

1- نجد مؤشر أويلر للعدد n :

2- نحل المعادلة

لذا فانه من السهل خرق الامان في الخوارزمية إذا ما توجد خوارزمية تحليل لعوامل بسرعة. ولكن لا يوجد خوارزمية سريعة لفعل هذا ! لذا يمكن اعتبار هذا الخرق غير مُعتبر.

ملاحظة: بيتر شور، في عام 1997 قدم خوارزمية سريعة لايجاد العوامل ولكن ذلك كان بمساعدة ادوات فيزيائية بالتحديد بواسطة الحسابات الكمومية. وهذه الخوارزمية لا تُعتبر قابلة للبرمجة لانها تحتاج حاسوب كمومي وهو غير موجود للآن (أي عام 2013) ولكن هناك بصيص من الامل لامكانية اختراع مثل هذه الحواسيب.

  • p و- q لا يجب أن يكون قريبين جدا خشية ان التحليل إلى العوامل على طريقة «فيرمات» ل n ان تكون ناجحة، إذا p و q على سبيل المثال هم اقل من سوف يكون الحل ل p و q سهل. بالإضافة إلى ذلك إذا كانت أي من p -1 أو q-1 لهم عوامل اولية صغيرة فقط، ممكن ان تحلل n إلى عواملها يشكل سريع عن طريق «خوارزمية بولارد» وهذه القيم ل p و q يجب أن تهمل.
  • من المهم ان يكون المفتاح السري كبير كفاية، حيث اثبت السيد michel wiener في عام 1990 انه إذا و فان d يمكن حسابها على نحو كاف من قيم n و e. لا يوجد هجوم معروف ضد الاسس الصغيرة العامة مثل e=3 باشتراط استخدام تبطين مناسب، على كل حال في حين عدم استخدام تبطين أو عمله بشكل خاطيء فان الاسس الصغيرة العامة لها مخاطرة أكبر تؤدي إلى هجوم، كما هو الحال في ضعف النص الصريح غير المبطن. 65537 هو قيمة تستخدم في غالب الأحيان ل e. هذه القيمة من الممكن ان تعتبر انها حل وسط بين تجنب الهجومات الاسية الصغيرة المحتملة ومع ذلك تسمح بالتعمية ات الفعالة.

إيجاد أعداد أولية

[عدل]

لإيجاد أعداد أولية و نختار بشكل عشوائي أعدادا ويتم فحصها. لذا كل ما يُحتاج إليه هو وسيلة لفحص الأولية بطريقة سريعة. هناك عدة خوارزميات منها خوارزميات احتمالية مثل اختبار ميلر-رابن لأولية عدد ما وأخرى حتمية مثل اختبار أ.ك.أس.

السرعة

[عدل]

RSA أبطا بكثير من ال DES ونظم التعمية المتناسقة. مع التجربة على سبيل المثال أحمد يقوم بتعمية رسالة سرية بواسطة خوارزمية متناسقة، يشفر المفتاح التناسق بواسطة ال RSA ومن ثم يبعث المفتاح المتناسق المشفر بواسطة الRSA والرسالة المشفرة تعمية ا تناسقيا إلى سهيلة. هذا الاجراء يرفع المزيد من الاحتياطات الأمنية. فعلى سبيل المثال: المهمة الكبرى هي استخدام مولد ارقام عشوائية قوي للمفتاح المتناسق لان توفيق (مختلس السمع يريد ان يرى ما تم بعثة) يمكن ان يجتاز الRSA فقط بتخمين المفتاح المتناسق.

توزيع المفاتيح

[عدل]

كما في كل الشيفرات، كيفية توزيع مفاتيح آر إس إيه العامة مهم جدا الأمن. يجب أن يكون توزيع المفاتيح آمنا جدا ضد هجوم الرجل في الوسط. لنفترض أن توفيق له طريقة ما لإعطاء أحمد مفاتيح تحكمية وجعله يصدق أن هذه المفاتيح هي مفاتيح سهيلة. لنفترض أيضا أن سهيلة قادرة على أن تقطع الرسائل بين أحمد وتوفيق. سهيلة تقوم بارسال مفتاحها العام لأحمد والتي يعتقد أحمد أنها مفاتيح توفيق، ومن ثم يستطيع توفيق أن يقطع أي نص مشفر مرسل بواسطة أحمد ومن ثم فك تعمية ه بمفتاحه السري الخاص وابقاء نسخة من هذه الرسالة ومن ثم تعمية ها بمفتاح سهيلة ثم إرسال النص المشفر الجديد لسهيلة. في الحقيقة أن أحمد وسهيلة لا يستطيعوا أن يكشفوا وجود توفيق. الدفاعات ضد هذه الهجومات كثيرا ما تكون معتمدة على الشهادات الرقمية أو مكونات أخرى للبنية التحتية للمفتاح العام.

انظر أيضا

[عدل]

المراجع

[عدل]
  1. ^ Calderbank، Michael (20 أغسطس 2007). "The RSA Cryptosystem: History, Algorithm, Primes" (PDF). مؤرشف من الأصل (PDF) في 2016-12-13.
  2. ^ Probabilistic encryption & how to play mental poker keeping secret all partial information, Annual ACM Symposium on Theory of Computing, 1982. نسخة محفوظة 31 مارس 2020 على موقع واي باك مشين.
  3. ^ Coppersmith، Don (1997). "Small Solutions to Polynomial Equations, and Low Exponent RSA Vulnerabilities" (PDF). Journal of Cryptology. ج. 10 ع. 4: 233–260. DOI:10.1007/s001459900030. مؤرشف من الأصل (PDF) في 2017-09-22.