آراسای
در بحث رمزنگاری، آراساِی (RSA) شیوهای برای رمزنگاری به روش کلید عمومی (Public Key) است. این روش نخستین روش مورد اعتماد در بین روشهای رمزنگاری دیگر است و یکی از بزرگترین پیشرفتها در زمینهٔ رمزنگاری به حساب میآید. آراسای همچنان به صورت وسیعی در تبادلات الکترونیکی استفاده میشود و در صورت استفاده درست با کلیدهای طولانی کاملاً امن به نظر میرسد.
محتویات |
تاریخچه [ویرایش]
این روش نخستین بار در سال ۱۹۷۷ توسط رونالد ریواست، آدی شامیر و لئونارد آدلمن در دانشگاه ام آی تی مطرح شد. اصطلاح آراسآ نیز از حروف ابتدای نام آنها گرفته شده است. دانشگاه امآیتی حق اختراع[۱] این روش را به نام خود ثبت کرد. این حق اختراع در ۲۱ سپتامبر سال ۲۰۰۰ میلادی منقضی شد.
توضیحات کارکرد [ویرایش]
کلیات [ویرایش]
آراسای به طور کلی از دو کلید تشکیل میشود. کلید عمومی و کلید خصوصی. کلید عددی ثابت است که در محاسبات رمزنگاری استفاده میشود. کلید عمومی برای همه معلوم بوده و برای رمز کردن پیام استفاده میشود. این پیام فقط توسط کلید خصوصی باز میشود. به عبارتی دیگر همه میتوانند یک پیام را رمز کنند اما فقط صاحب کلید خصوصی میتواند پیام را باز کند و بخواند.
تولید کلید [ویرایش]
مراحل زیر برای تولید کلید طی میشود:
- دو عدد اول بزرگ
و
را به صورت تصادفی بیابید به طوری که
. - عدد n را محاسبه کنید به طوری که
. - تابع فی را محاسبه کنید به طوری که

- عدد
را انتخاب کنید به طوری که
و نسبت به
اول باشد.
- عدد
به عنوان توان کلید عمومی منتشر میشود.
- عدد
- عدد
را طوری بیابید که
(باقیمانده ضرب دو عدد
و
نسبت به
برابر ۱ باشد، به صورت:
به ازای kهای طبیعی)
- عدد
به عنوان توان کلید خصوصی محافظت میشود.
- عدد
- دو عدد اول میتوانند توسط روش پیدا کردن اعداد اول احتمالی پیدا شوند.
- معمولاً عدد عمومی (e) را در حدود ۲۱۶ انتخاب میکنند. البته بعضی برنامه اعداد کوچکی را انتخاب میکنند که باعث سریعتر شدن و البته خطرات امنیتی در رمزنگاری میشود.
- کلید عمومی تشکیل میشود از :
- عدد n (عدد مشترک)
- عدد e (عدد عمومی)
- کلید خصوصی تشکیل میشود از :
- عدد n (عدد مشترک)
- عدد d (عدد خصوصی)
- کلید خصوصی به صورتهای دیگری غیر از
ممکن است نگهداری شود.
و
: اعداد اول برای ساختن کلید.
و
،
.
- در تمام مراحل باید اجزای کلید خصوصی سری نگه داشته شود، دو عدد
و
اگر به عنوان صورتی از کلید خصوصی نگهداری نشود بهتر است به شیوهای امن نابود شوند. زیرا با این دو عدد تمام اعداد
و
،
قابل محاسبه خواهند بود.
رمز کردن پیام [ویرایش]
فرض کنید می خواهید پیامی را رمزنگاری کرده و به فردی دیگر بفرستید. شما می بایست کلید عمومی آن فرد را از او دریافت کرده و پیام خود را در قالب یک عدد (m) در بیاورید به طوری که این فرآیند برگشت پذیر بوده و عدد شما از n کوچکتر باشد. بدیهی است اگر پیام بزرگتر حد معمول باشد آن را در بستههای جداگانه می فرستیم. شما اکنون عدد C را محاسبه می کنید به طوری که
حال اگر پیام رمزنگاری شدهٔ C را برای فرد مذکور بفرستید او میتواند توسط کلید خصوصی اش آن را باز کندو بفهمد.
باز کردن پیام [ویرایش]
فرض کنید شما پیام رمز نگاری شدهٔ C را دریافت کرده اید و کلید خصوصی خود را در دسترس دارید. حال شما میتوانید عدد m را که معادل پیام اصلی است از C،n،d بازیابی کنید. 
پانویس [ویرایش]
- ↑ (Patent)
منابع [ویرایش]
- R. Rivest، A. Shamir، L. Adleman. A Method for Obtaining Digital Signatures and Public-Key Cryptosystems. Communications of the ACM، Vol. ۲۱ (۲)، pp.۱۲۰–۱۲۶. ۱۹۷۸. Previously released as an MIT "Technical Memo" in April ۱۹۷۷. انتشار اولیه روش رمز نگاری آر اس ای.
- توماس اچ کورمن، Charles E. Leiserson، Ronald L. Rivest، and کلیفورد استین. مقدمهای بر الگوریتمها، Second Edition. MIT Press and McGraw-Hill، ۲۰۰۱. ISBN ۰-۲۶۲-۰۳۲۹۳-۷. Section ۳۱.۷: The RSA public-key cryptosystem، pp.۸۸۱–۸۸۷.
و
را به صورت تصادفی بیابید به طوری که
.
.
را انتخاب کنید به طوری که
و نسبت به
اول باشد.
را طوری بیابید که
(باقیمانده ضرب دو عدد
برابر ۱ باشد، به صورت:
به ازای kهای طبیعی)
و
: اعداد اول برای ساختن کلید.
و
،
.
و