رمزنگاری
دانشی است که به بررسی و شناختِ اصول و روشهای انتقال یا ذخیرهٔ اطلاعات به صورت
امن (حتی اگر مسیر انتقال اطلاعات و کانالهای ارتباطی یا محل ذخیره اطلاعات ناامن
باشند) میپردازد.
رمزنگاری
استفاده از تکنیکهای ریاضی، برای برقراری امنیت اطلاعات است. دراصل رمزنگاری دانش
تغییر دادن متن پیام یا اطلاعات به کمک کلید رمز و با استفاده از یک الگوریتم رمز
است، به صورتی که تنها شخصی که از کلید و الگوریتم مطلع است قادر به استخراج
اطلاعات اصلی از اطلاعات رمز شده باشد و شخصی که از یکی یا هر دوی آنها اطلاع
ندارد، نتواند به اطلاعات دسترسی پیدا کند. دانش رمزنگاری بر پایه مقدمات بسیاری
از قبیل تئوری اطلاعات، نظریه اعداد و آمار بنا شدهاست و امروزه به طور خاص در
علم مخابرات مورد بررسی و استفاده قرار میگیرد. معادل رمزنگاری در زبان انگلیسی
کلمه Cryptography
است، که برگرفته از لغات یونانی kryptos
به مفهوم «محرمانه» و graphien
به معنای «نوشتن» است.
تاریخچه
رمزنگاری سابقهای طولانی و جذاب دارد، که
اولین کاربرد آن به ۴۰۰۰ سال پیش در مصر باستان
بازمیگردد.
رمزنگاری، پنهاننگاری،
کدگذاری
در رمزنگاری، وجود اطلاعات یا
ارسال شدن پیام به هیچ وجه مخفی نمیباشد، بلکه ذخیره اطلاعات یا ارسال پیام مشخص
است، اما تنها افراد مورد نظر میتوانند اطلاعات اصلی را بازیابی کنند. بالعکس در
پنهاننگاری، اصل وجود اطلاعات یا ارسال پیام محرمانه، مخفی نگاه داشته میشود و
غیر از طرف ارسالکننده و طرف دریافتکننده کسی از ارسال پیام آگاه نمیشود.
در رمزنگاری محتویات یک متن
به صورت حرف به حرف و در بعضی موارد بیت
به بیت تغییر داده میشود و
هدف تغییر محتوای متن است نه تغییر ساختار زبانشناختی آن. در مقابل کدگذاری
تبدیلی است که کلمهای را با
یک کلمه یا نماد دیگر جایگزین میکند و ساختار زبانشناختی متن را تغییر میدهد
رمزنگاری پیشرفته
با پدید آمدن رایانهها و
افزایش قدرت محاسباتی آنها، دانش رمزنگاری وارد حوزهٔ علوم رایانه گردید و این
پدیده، موجب بروز سه تغییر مهم در مسائل رمزنگاری شد:
- وجود قدرت محاسباتی بالا این امکان را پدید
آورد که روشهای پیچیدهتر و مؤثرتری برای رمزنگاری به وجود آید.
- روشهای رمزنگاری که تا قبل از آن اصولا برای
رمز کردن پیام به کار میرفتند، کاربردهای جدید و متعددی پیدا کردند.
- تا قبل از آن، رمزنگاری عمدتاً روی اطلاعات
متنی و با استفاده از حروف الفبا انجام میگرفت؛ اما ورود رایانه باعث شد که
رمزنگاری روی انواع اطلاعات و بر مبنای بیت انجام شود.
تعاریف و اصطلاحات
عناصر مهمی که در رمزنگاری
مورد استفاده قرار میگیرند به شرح زیر میباشد:
پیام و اطلاعات را در حالت
اصلی و قبل از تبدیل شدن به حالت رمز، متن آشکار یا اختصارا پیام مینامند. در این
حالت اطلاعات قابل فهم توسط انسان است.
به پیام و اطلاعات بعد از
درآمدن به حالت رمز، گفته میشود. اطلاعات رمز شده توسط انسان قابل فهم نیست.
عملیاتی است که با استفاده از
کلید رمز، پیام را به رمز تبدیل میکند.
عملیاتی است که با استفاده از
کلید رمز، پیام رمز شده را به پیام اصلی باز میگرداند. از نظر ریاضی، این
الگوریتم عکس الگوریتم رمز کردن است.
اطلاعاتی معمولاً عددی است که
به عنوان پارامتر ورودی به الگوریتم رمز داده میشود و عملیات رمزگذاری
و رمزگشایی
با استفاده از آن انجام میگیرد.
انواع مختلفی از کلیدهای رمز در رمزنگاری تعریف و استفاده میشود.
الگوریتم رمزنگاری
الگوریتم رمزنگاری، به هر
الگوریتم یا تابع ریاضی گفته میشود که به علت دارا بودن خواص مورد نیاز در
رمزنگاری، در پروتکلهای رمزنگاری مورد استفاده قرار گیرد. اصطلاح الگوریتم
رمزنگاری یک مفهوم جامع است و لازم نیست هر الگوریتم از این دسته، به طور مستقیم
برای رمزگذاری اطلاعات مورد استفاده قرار گیرد، بلکه صرفاً وجود کاربرد مربوط به
رمزنگاری مد نظر است.
در گذشته سازمانها و شرکتهایی
که نیاز به رمزگذاری یا سرویسهای دیگر رمزنگاری داشتند، الگوریتم رمزنگاری
منحصربهفردی را طراحی مینمودند. به مرور زمان مشخص گردید که گاهی ضعفهای امنیتی
بزرگی در این الگوریتمها وجود دارد که موجب سهولت شکسته شدن رمز میشود. به همین
دلیل امروزه رمزنگاری مبتنی بر پنهان نگاه داشتن الگوریتم رمزنگاری منسوخ شدهاست
و در روشهای جدید رمزنگاری، فرض بر این است که اطلاعات کامل الگوریتم رمزنگاری
منتشر شدهاست و آنچه پنهان است فقط کلید رمز است.
بنا بر این تمام امنیت حاصل
شده از الگوریتمها و پروتکلهای رمزنگاری استاندارد، متکی به امنیت و پنهان ماندن
کلید رمز است و جزئیات کامل این الگوریتمها و پروتکلها برای عموم منتشر میگردد.
رمزنگاری کلید متقارن
رمزنگاری کلید متقارن∗ یا تک کلیدی، به آن
دسته از الگوریتمها، پروتکلها و سیستمهای رمزنگاری گفته میشود که در آن هر دو
طرف رد و بدل اطلاعات از یک کلید رمز یکسان برای عملیات رمزگذاری و رمزگشایی
استفاده میکنند. در این قبیل سیستمها، یا کلیدهای رمزگذاری و رمزگشایی یکسان
هستند و یا با رابطهای بسیار ساده از یکدیگر قابل استخراج میباشند و رمزگذاری و
رمزگشایی اطلاعات نیز دو فرآیند معکوس یکدیگر میباشند.
واضح است که در این نوع از
رمزنگاری، باید یک کلید رمز مشترک بین دو طرف تعریف گردد. چون کلید رمز باید
کاملاً محرمانه باقی بماند، برای ایجاد و رد و بدل کلید رمز مشترک باید از کانال
امن استفاده نمود یا از روشهای رمزنگاری نامتقارن استفاده کرد.
نیاز به وجود یک کلید رمز به ازای هر دو نفرِ درگیر در رمزنگاری متقارن، موجب بروز
مشکلاتی در مدیریت کلیدهای رمز میگردد.
رمزنگاری کلید نامتقارن
رمزنگاری کلید نامتقارن∗،
در ابتدا با هدف حل مشکل انتقال کلید در روش متقارن و در قالب پروتکل تبادل کلید دیفی-هلمن
پیشنهاد شد. در این نوع از
رمزنگاری، به جای یک کلید مشترک، از یک زوج کلید به نامهای کلید عمومی
و کلید خصوصی
استفاده میشود. کلید خصوصی
تنها در اختیار دارندهٔ آن قرار دارد و امنیت رمزنگاری به محرمانه بودن کلید خصوصی
بستگی دارد. کلید عمومی در اختیار کلیهٔ کسانی که با دارندهٔ آن در ارتباط هستند
قرار داده میشود.
به مرور زمان، به غیر از حل
مشکل انتقال کلید در روش متقارن، کاربردهای متعددی برای این نوع از رمزنگاری مطرح
گردیدهاست. در سیستمهای رمزنگاری نامتقارن، بسته به کاربرد و پروتکل مورد نظر،
گاهی از کلید عمومی برای رمزگذاری و از کلید خصوصی برای رمزگشایی
استفاده میشود و گاهی نیز،
بر عکس، کلید خصوصی برای رمزگذاری و کلید عمومی برای رمزگشایی به کار میرود.
دو کلید عمومی و خصوصی با
یکدیگر متفاوت هستند و با استفاده از روابط خاص ریاضی محاسبه میگردند. رابطهٔ
ریاضی بین این دو کلید به گونهای است که کشف کلید خصوصی با در اختیار داشتن کلید
عمومی، عملاً ناممکن است.
مقایسه رمزنگاری کلید متقارن
و کلید نامتقارن
اصولاً رمزنگاری کلید متقارن
و کلید نامتقارن دارای دو ماهیت متفاوت هستند و کاربردهای متفاوتی نیز دارند. بنا
بر این مقایسهٔ این دو نوع رمزنگاری بدون توجه به کاربرد و سیستم مورد نظر کار
دقیقی نخواهد بود. اما اگر معیار مقایسه، به طور خاص، حجم و زمان محاسبات مورد
نیاز باشد، باید گفت که با در نظر گرفتن مقیاس امنیتی معادل، الگوریتمهای
رمزنگاری متقارن خیلی سریعتر از الگوریتمهای رمزنگاری نامتقارن میباشند.
تجزیه و تحلیل رمز
تجزیه و تحلیل رمز∗ یا شکستن رمز، به کلیهٔ
اقدامات مبتنی بر اصول ریاضی و علمی اطلاق میگردد که هدف آن از بین بردن امنیت
رمزنگاری و در نهایت باز کردن رمز و دستیابی به اطلاعات اصلی باشد. در تجزیه و
تحلیل رمز، سعی میشود تا با بررسی جزئیات مربوط به الگوریتم رمز و یا پروتکل
رمزنگاری مورد استفاده و به کار گرفتن هرگونه اطلاعات جانبی موجود، ضعفهای امنیتی
احتمالی موجود در سیستم رمزنگاری یافته شود و از این طریق به نحوی کلید رمز به دست
آمده و یا محتوای اطلاعات رمز شده استخراج گردد.
تجزیه و تحلیل رمز، گاهی به
منظور شکستن امنیت یک سیستم رمزنگاری و به عنوان خرابکاری و یک فعالیت ضد امنیتی
انجام میشود و گاهی هم به منظور ارزیابی یک پروتکل یا الگوریتم رمزنگاری و برای
کشف ضعفها و آسیبپذیریهای احتمالی آن صورت میپذیرد. به همین دلیل، تجزیه و
تحلیل رمز، ذاتاً یک فعالیت خصومتآمیز به حساب نمیآید؛ اما معمولاً قسمت ارزیابی
و کشف آسیبپذیری را به عنوان جزئی از عملیات لازم و ضروری در هنگام طراحی
الگوریتمها و پروتکلهای جدید به حساب میآورند و در نتیجه تجزیه و تحلیل رمز
بیشتر فعالیتهای خرابکارانه و ضد امنیتی را به ذهن متبادر میسازد. با توجه به
همین مطلب از اصطلاح حملات تحلیل رمز∗ برای اشاره به چنین فعالیتهایی
استفاده میشود.
تحلیل رمز، در اصل اشاره به
بررسی ریاضی الگوریتم (یا پروتکل) و کشف ضعفهای احتمالی آن دارد؛ اما در خیلی از
موارد فعالیت خرابکارانه، به جای اصول و مبنای ریاضی، به بررسی یک پیادهسازی خاص
آن الگوریتم (یا پروتکل) در یک کاربرد خاص میپردازد و با استفاده از امکانات مختلف
سعی در شکستن رمز و یافتن کلید رمز مینماید. به این دسته از اقدامات خرابکارانه، حملات
جانبی∗ گفته میشود.
رمزهای جانشینی
در رمز نگاری جانشینی هر حرف
یا گروهی از حروف بایک حرف یا گروهی دیگراز حروف جابجا میشوند تا شکل پیام بهم
بریزد.یکی از قدیمیترین رمزهای شناخته شده روش رمز نگاری سزار است که ابداع آن به
ژولیوس سزار نسبت داده میشود.در این روش حرف
a به
d تبدیل میشود
bبه
c، e به
fوبه همین ترتیب تاz که با حروفc جایگزین میشوند.
افزونگی
اولین اصل آن است که تمام
پیامهای رمز شده بایدشامل مقداری«افزونگی»[دادههای زائد]باشندبه عبارت دیگر لزومی
ندارد که اطلاعات واقعی به همان گونه که هستند رمز و ارسال شوند. یک مثال میتواند
به فهم دلیل این نیاز کمک کند. فرض کنید یک شرکت به نام
TCP با۶۰۰۰۰کالااز طریق سیستم پست
الکترونیکی سفارش خرید میپذیرد. برنامه نویسان شرکت
TCP به خیال آن که برنامههای موثر و کار آمدی مینویسند پیامهای
سفارش کالا را مشتمل بر ۱۶بایت نام مشتری و به دنبال آن
سه بایت فیلد داده (شامل یک بایت برای تعدادکالا ودو بایت برای شمارهٔ کالا)در نظر
میگیرد که سه بایت آخر توسط یک کلید بسیار طولانی رمزنگاری میشود واین کلید را
فقط مشتری و شرکت TCP میداند.
تازگی پیامها
دومین اصل اساسی در رمزنگاری
آن است که باید محاسباتی صورت بگیرد تا مطمئن شویم هرپیام دریافتی تازه و جدید است
یا به عبارتی اخیراً فرستاده شدهاست این بررسی برای جلوگیری از ارسال مجدد پیامهای
قدیمی توسط یک اخلالگر فعّال الزامی است اگر چنین بررسیهایی انجام نشود کارمند
اخراجی ما قادر است با ایجاد یک انشعاب مخفی از خط تلفن پیامهای معتبری را که
قبلاً ارسال شده مکرراً ارسال نماید، حتی اگر نداند محتوای ان چیست.
راهکاری برای ایجاد تازگی
پیام
ک چنین محاسبهای را میتوان
با قرار دادن یک مهر زمان در پیامها پیش بینی کرد به نحوی که پیامها مثلاً برای
ده ثانیه معتبر باشد گیرندهٔ پیام میتواند آن را برای حدود ده ثانیه نگه دارد تا
بتواند پیامهای جدید را با آن مقایسه کرده و نسخههای تکراری را که دارای مهر
زمان هستند به عنوان پیامهای قدیمی شناخته و حذف خواهند شد.
رمزنگاری به صورت سختافزاری
الگوریتمهای رمزنگاری رامی
توان هم به صورت سختافزاری(به منظورسرعت بالاتر) وهم به صورت نرمافزاری (برای
انعطاف پذیری بیشتر) پیاده سازی کرد روشهای جانشینی وجایگشتی میتوانند با یک مدار
سادهٔ الکترونیکی پیاده سازی شوند. p-box ابزاری است که برای جایگشت
بیتهای یک ورودی هشت بیتی کاربرد دارد.بود با سیم بندی و برنامه ریزی درونی این
p-box قادراست هر گونه جایگشت بیتی راعملاً با سرعتی نزدیک به سرعت
نور انجام بدهد چرا که هیچ گونه محاسبهای لازم نیست وفقط تأخیر انتشار سیگنال
وجود دارد.این طراحی از اصل کرکهف تبعیت میکند یعنی:حمله کننده از روش عمومی
جایگشت بیتها مطلّع است آن چه که او از آن خبر ندارد آن است که کدام بیت به کدام
بیت نگاشته میشود کلید رمز همین است.
برخی اصطلاحات
در لیست زیر با توجه به
ارتباط مستقیم علم رمزنگاری یا همان Cryptography به برخی از اصطلاحات که در
بحث امنیت شبکه و کامپیوتر وجود دارند اشاره شده است
Encryption
در علم
cryptography به پنهان سازی اطلاعات گفته میشود.
Decryption
معکوس
encryption است و در crypto به آشکار سازی اطلاعات پنهان
شده گفته میشود
Plain
text
به متنی گفته میشود که معنای
آن بدون تغییر خاصی قابل درک است.
Cipher
به روشی برای تبدیل
plain text به متنی که معنای آن پنهان باشد
cipher گفته میشود.
Cryptanalysis
به هنر شکستن متون
cipher شده گفته میشود.
Intruder
ر لغت به معنای مزاحم است ولی
در اینجا به معنای کسی است که یک کپی از cipher text دارد و تمایل به شکستن رمز
دارد. منظور از شکستن رمز یعنی decrypt کردن آن متن که خود دو نوع
است activeintruder که میتواند اطلاعات را روی
خط عوض کند و تغییر دهد و passive intruder که فقط میتواند اطلاعات روی
خط را داشته باشد و قابلیت تغییر آنها را ندارد.
Protocol
به روش و یا قرار دادی که بین
دو یا چند نفر برای تبادل اطلاعات گذاشته میشود گفته میشود.
Intrusion
Points
نقاطی که یک نفوذگر بتواند به
اطلاعات با ارزش دست پیدا کند.
Internal
Access Point
به سیستمهایی گویند که در
اتاق یا در شبکه داخلی مستقرند و هیچ امنیتی
( LocalSecurity) روی آنها تنظیم نشده باشد و احتمال حمله به آنها وجود دارد.
External
Access Point
تجهیزاتی که ما را به شبکه
خارجی مانند اینترنت متصل میکنند یا Applicationهایی که از طریق اینترنت کار
میکنند و احتمال حمله به آنها وجود دارد.
Attack
هر چیزی که مکانیزم امنیت
سیستم شما را دور زده و باعث تخریب گردد را حمله یا Attack گویند. از انواع حمله میتوان
به موارد زیر اشاره کرد:
- DoS
- DDoS
- Spoofing ( مانند MAC Spoofing ، IP
Spoofing و Web
Spoofing )
- Man-in-the-Middle
5. Password G