From Wikipedia, the free encyclopedia
پروتکل امن انتقال ابرمتن یا HTTPS (به انگلیسی: Hypertext Transfer Protocol Secure) یک پروتکل ارتباطی برای انتقال امن اطلاعات در شبکههای کامپیوتری است که به صورت خاص در اینترنت استفاده میشود. HTTPS شامل یک ارتباط بر روی پروتکل انتقال ابرمتن است که توسط امنیت لایه انتقال رمزگذاری میشود. مهمترین اهداف استفاده از HTTPS اصالتسنجی وبگاه، حفاظت از حریم خصوصی و یکپارچگی دادههای انتقالی است.
در نسخهٔ رایج پروتکل HTTPS اصالتسنجی وبگاهها وجود دارد. این امر جلوی حملات مرد میانی[پانویس 1] را میگیرد. همچنین رمزگذاری ۲طرفه بین کلاینت[پانویس 2] (یا کارخواه) و سرور[پانویس 3] (یا کارگزار) از حملات شنود و تغییر بدون اجازه جلوگیری میکند.[1] در عمل، این ویژگیها باعث میشود تا این پروتکل بتواند تا حد زیادی امنیت ارتباط کاربران را تأمین نماید.
در ابتدا از این پروتکل فقط برای انجام تراکنشهای بانکی، ارسال ایمیلهای مهم و کارهای حساس دیگر بر روی وب جهانی استفاده میشد اما با گذشت زمان، استفاده از آن بیشتر و بیشتر میشود.[2][3] امن کردن ارتباطات کاربران، شناسایی وبگاههای معتبر و مخفی کردن هویت کاربران از جمله استفادههای نوین این پروتکل است.[4] البته باید توجه داشت که امنیت کامل کاربران تنها در صورتی تأمین میشود که تمامی محتویات وبگاه از طریق همین پروتکل منتقل شود. منابعی مانند فایلهای اسکریپت، کوکیها و غیره نمونههایی هستند که انتقال غیرامن آنها تهدید امنیتی محسوب میشود.[5]
یوآرآیهای[پانویس 4] HTTPS ساختاری شبیه آدرسهای پروتکل انتقال ابرمتن دارند با این تفاوت که آنها با https آغاز میشوند. وجود کلمهٔ HTTPS در ابتدای آدرس، به مرورگر نشان میدهد که برای اتصال به وبگاه باید از امنیت لایه انتقال[پانویس 5] استفاده کند.[6][7] از آنجا که در این پروتکل حتی اگر یکی از طرفین هم اصالتسنجی شده باشد، امنیت برقرار خواهد شد، استفادهٔ آن در وب بسیار مناسب است. در اینترنت معمولاً وبگاهها گواهی اصالتسنجیشده تهیه میکنند. کاربران با بررسی صحت گواهی وبگاه، میتوانند از هویت وبگاه مطمئن شده و ارتباطی امن و غیرقابل شنود داشتهباشند.[8][9]
HTTPS بر روی یک شبکه غیر امن، مانند اینترنت، یک بستر امن ایجاد میکند.[10] این امر به شرطی که گواهی وبگاه مقصد مورد تأیید و الگوریتمهای مورد استفاده مناسب باشند، تا حد زیادی جلوی انواع حملات شنود و حملهٔ مرد میانی را میگیرد.[5]
از آنجایی که HTTPS، پروتکل امنیت لایه انتقال را بهطور کامل در لایهای در زیر HTTP قرار میدهد، تمامی محتویات بستهٔ HTTP رمزگذاری میگردد. این اطلاعات شامل نشانی وب[پانویس 6] (آدرس صفحهٔ مقصد)، پارامترهای ارسالی (مانند نامِ کاربری و کلمهٔ عبور)، سرآیندها و کوکیها میشوند. اما از آنجا که لایهٔ TCP/IP[پانویس 7] به آدرس IP و شمارهٔ درگاه نیازمند است، پروتکل HTTPS نمیتواند از آنها محافظت کند. برای مثال در یک ارتباط امن با وبگاه گوگل، هیچکس نمیتواند از روی بستهٔ کاربر متوجه محتویات درخواست او شود؛ اما از روی بسته میتوان به آدرس، شماره درگاه، حجم اطلاعات انتقالی و طول مدت ارتباط دست یافت.[1]
مرورگرهای وب با استفاده از مراجع صدور گواهی دیجیتال که به صورت پیشفرض در درون آنها نصب شدهاست، میتوانند صحت یا جعلی بودن گواهی یک وبگاه را تشخیص دهند.[11][12][13] این بدان معنی است که کاربران به صورت پیشفرض از طریق مرورگر به شرکتهای صادرکننده گواهیهای دیجیتال (مانند شرکت وریساین، مایکروسافت و غیره) اعتماد میکنند تا گواهیهای وبگاههای مختلف را برایشان تأیید نمایند؛ بنابراین یک اتصال HTTPS به یک وبگاه امن است اگر و تنها اگر تمام موارد زیر صدق کند:
استفاده از HTTPS در شبکههای عمومی (مانند شبکههای وای-فای) بسیار ضروری است. در این شبکهها امکان شنود بستهها به راحتی برای تمام افراد حاضر در شبکه وجود دارد.[1] همچنین گزارشهایی از ارائه دهندگان سرویس شبکه محلی بیسیم نشان میدهد که این شرکتها از اطلاعات مشتریان خود سوءاستفاده کرده و در بعضی از موارد با استفاده از تغییر در ارتباط، تبلیغات خود یا حتی بدافزارهایی را به سیستم مشتریها منتقل کردهاند.[15] بنابراین بهتر است تمامی اطلاعات بر روی این نوع شبکهها توسط پروتکلهای امن منتقل شود.
بر اساس آمارهای منتشر شده تا تاریخ ۲ اوت سال ۲۰۱۷ میلادی، از حدود ۱۴۰هزار وبگاه معتبر، ۶۰٪ این پروتکل امن را پیادهسازی کرده و از آن استفاده میکنند.[16]
تقریباً تمامی مرورگرهای وب در صورت دریافت یک گواهی نامعتبر به اشکال مختلف به کاربر هشدار میدهند.[13] برخی از مرورگرهای قدیمیتر، با نمایش یک جعبه هشدار[پانویس 8] وضعیت را به کاربر گزارش داده و برای ادامهٔ کار از او اجازه میگرفتند. اما مرورگرهای جدیدتر معمولاً با هشدارهای واضح که تمامی صفحه را پر میکنند، سعی در مطلع ساختن کاربر از خطرهای احتمالی را دارند. (مانند تصاویر)[17][18] همچنین علامتهایی مانند کلید یا سبز یا قرمز شدن نوار آدرس در مرورگرهای مختلف نشانهٔ مورد تأیید یا جعلی بودن گواهی ارائه شده توسط وبگاه است.[19][20] امروزه بسیاری از مرورگرها در صورتی که محتویات صفحه مخلوطی از پروتکل امن و غیر امن HTTP باشد، به کاربر هشدار خواهند داد.[21][22]
مرورگر فایرفاکس از نسخهٔ ۱۴، براساس اعلام خود، جهت «محافظت از کاربران در برابر زیرساختهایی از شبکه که منجر به جمعآوری اطلاعات یا تغییر و سانسور کردن نتایج جستجو میشوند» به صورت پیشفرض جستجوهای وبگاه گوگل را با پروتکل HTTPS انجام میدهد.[23][24]
بنیاد مرزهای الکترونیکی[پانویس 10] که عقیده دارد «در یک دنیای آرمانی، تمامی درخواستهای شبکه وب بهطور پیشفرض امن خواهند بود»، اقدام به انتشار افزونهای برای مرورگرهای فایرفاکس، گوگلکروم و کرومیوم به نام HTTPS Everywhere (همهجا HTTPS) نمودهاست. این افزونه تمامی صفحات ممکن را با استفاده از این پروتکل امن نمایش میدهد.[25]
برخلاف نشانیهای وب[پانویس 6] HTTP که با «http://
» آغاز میشوند و به صورت پیشفرض از درگاه شمارهٔ ۸۰ استفاده میکنند، آدرسهای HTTPS با «https://
» آغاز شده و به صورت پیشفرض از شماره درگاه ۴۴۳ استفاده میکنند.[26]
HTTP امن نیست و میتواند هدف حملههای مرد میانی[پانویس 1] و شنود[پانویس 11] قرار بگیرد. این حملات به مهاجم اجازه میدهد به اطلاعات حساس مانند حسابهای کاربر دسترسی پیدا کند. HTTPS با این هدف طراحی شدهاست که جلوی چنین حملاتی را بگیرد و از این جهت امن است.[1] (به استثنای نسخههای کنارگذاشتهشده و قدیمیتر آن)
سرعت پروتکل HTTPS، به ویژه در صفحاتی با محتوای زیاد، معمولاً از پروتکل غیر امن آن کمتر است. ارسال گواهی، تأیید گواهی توسط مرورگر و سربار رمزگذاری بر روی سیستم از مهمترین دلایل این کندی هستند. یک اتصال امن در شروع حدوداً ۱۰٪ کندتر از یک اتصال غیر امن است. اما با استفاده از اتصال پایا این کندی در ادامهٔ ارتباط تقریباً از بین میرود.[27]
HTTP در بالاترین لایهٔ مدل TCP/IP[پانویس 7] یعنی لایهٔ کاربرد عمل میکند. نسخهٔ امن آن نیز به صورت زیرلایهای در همین لایه فعال میشود. HTTPS قبل از رسیدن بستهٔ HTTP به لایهٔ پایینی (لایهٔ انتقال)، آن را رمزگذاری میکند (در هنگام دریافت پاسخ، رمزگشایی میکند). به صورت ساده، HTTPS پروتکل جدایی نیست، بلکه همان پروتکل HTTP است بر روی امنیت لایه انتقال.[پانویس 5][10]
در یک بستهٔ HTTPS همهٔ اطلاعات لایهٔ HTTP ازجمله نشانی وب،[پانویس 6] سرآیندها، کوکیها و اطلاعات ارسالی رمزگذاری میشوند.[10] یک حملهکننده پس از نفوذ میتواند متوجه آدرس آیپی مقصد، مدت زمان ارتباط و میزان اطلاعات ردوبدلشده شود. اما هیچچیز از محتویات ارتباط برای او فاش نخواهد شد.[1]
برای اینکه یک سرور وب بتواند اتصالات امن HTTPS را پشتیبانی کند، مدیر سرور[پانویس 12] باید یک گواهی کلید عمومی[پانویس 13] برای آن سرور تهیه کرده و آن را بر روی سرور نصب نماید.[28] این گواهی باید توسط یک مرجع صدور گواهی دیجیتال تأیید شود تا مرورگرها بتوانند بدون اخطار، صفحه را برای کاربر نمایش دهند. مرورگرها به صورت پیشفرض به تعدادی از مراجع صدور گواهی اعتماد دارند.
تهیهٔ یک گواهی دیجیتال معتبر میتواند رایگان یا بین ۸ تا ۱۵۰۰ دلار در سال هزینه داشته باشد.[29][30][31] البته باید توجه داشت که در بعضی موارد مراجع صدور گواهی رایگان مانند شرکت CACert در مرورگرهای مشهور (مانند فایرفاکس، گوگل کروم و اینترنت اکسپلورر) معتبر شناخته نمیشوند.[29]
مؤسسات و شرکتهای بزرگ، در صورتی که مسئول نصب و راهاندازی مرورگرها در محیط کار خود باشند، میتوانند با نصب گواهی خودشان بر رور مرورگرها، آنها را در محیط کار تأیید کنند (برای مثال یک وبگاه در شبکهٔ داخلی یک شرکت بزرگ یا دانشگاه). این مؤسسات میتوانند به راحتی کپی گواهی خود را بر روی مراجع مورد تأیید مرورگرها نیز ثبت کنند.[32]
یکی دیگر از استفادههای سیستم HTTPS و گواهیهای آن، احراز هویت کاربران برای مشخص نمودن سطح دسترسی آنها در وبگاه است. برای انجام این کار دو راه وجود دارد:
این گواهیها در درون خود اطلاعاتی مانند نام، نامِ خانوادگی و آدرس ایمیل کاربر را ذخیره میکنند. این اطلاعات با هر بار اتصال به وبگاه، توسط سرور بررسی شده و کاربر بدون نیاز به ورود نام کاربری یا کلیدواژه شناسایی خواهد شد.[33]
با به وجود آمدن سیاست Perfect Forward Secrecy در پروتکل HTTPS، لو رفتن و دزدیده شدن یک کلید خصوصی منجر به بهدست آمدن کلیدهای جلسهها و ارتباطات قبلی یا بعدی نمیشود.[34] پروتکل تبادل کلید دیفی-هلمن[پانویس 14] و تبادل کلید خم بیضوی دیفی-هلمن[پانویس 15] تنها الگوریتمهایی هستند که تاکنون (سال ۲۰۱۳) از این سیاست پیروی میکنند. البته این الگوریتمها سربار زیادی را به دلیل رمزنگاری پیچیده بر روی سرور و کلاینت خواهند گذاشت.[35]
اما این سیاست هنوز گسترده نشدهاست. در حال حاضر تنها ۳۰٪ اتصالات مرورگرهای فایرفاکس، گوگلکروم و اپرا از این روشها استفاده میکنند. این در حالی است که مرورگر سافاری و اینترنت اکسپلورر هیچگاه از این الگوریتمها استفاده نمیکنند.[36] از میان یاهو، مایکروسافت، پیپال، اپل، اچپی، دل، گوگل و تعداد بسیاری از شرکتهای بزرگ اینترنتی، تنها شرکت گوگل از این سیاست برای امنیت وبگاههای خود استفاده میکند.[37][38]
یک گواهی ممکن است قبل از اینکه منقضی شود، باطل گردد. دلایلی مانند لو رفتن کلید خصوصی یا دلایل امنیتی دیگر از جمله مواردی است که منجر به این موضوع میگردد. نسخههای جدید مرورگرهای مشهور مانند گوگلکروم، فایرفاکس، اینترنتاکسپلورر (از ویندوز ویستا به بعد) پروتکل برخط وضعیت گواهی[پانویس 16] را پیادهسازی کردهاند. به کمک این پروتکل مرورگرها میتوانند باطل شدن گواهیهای دیجیتال پیش از موعد را بررسی کنند. این عمل با ارسال شمارهسریال گواهی به مرجع آن صورت میگیرد.[39]
پروتکل HTTPS دو حالت مختلف را پشتیبانی میکند: حالت ساده[پانویس 17] و حالت متقابل یا دوطرفه.[پانویس 18][40]
حالت دوطرفه امنیت بیشتری دارد اما برای استفاده از آن علاوه بر سرور، کاربر نیز باید گواهی تهیه کرده و بر روی سیستمِ خود نصب نماید.[40]
هر کدام از این دو حالت که استفاده شوند، امنیت ارتباط به شدت به پیادهسازی و الگوریتم رمزنگاری استفادهشده دارد. سیستمهای مختلف بارها به دلیل مشکلاتی که در پیادهسازی آنها وجود دارد، مورد حمله قرار گرفتهاند.[41][42]
استفاده از ارتباط امن جلوی خزندههای وب را نمیگیرد. این خزندهها به راحتی صفحات امن را نیز فهرست میکنند. در بسیاری از موارد آدرس صفحات وبگاه تنها از روی حجم درخواست و پاسخ رمزنگاری شده، قابل افشا است.[43] این مسئله میتواند به یک مهاجم این امکان را بدهد که به متن رمز شده و رمز نشده دسترسی پیدا کند. این دسترسی میتواند امکان حمله متن رمز شده انتخابی[پانویس 19] را فراهم سازد.
از آنجایی که پروتکل HTTPS در لایهٔ زیرین HTTP فعالیت میکند، هیچ اطلاعی از عملکردِ لایههای بالاتر ندارد. هر سرور میتواند برای هر جفت آدرس IP و شماره درگاه خود یک گواهی به کاربر ارائه نماید.[44] به همین دلیل در بسیاری از موارد نمیتوان در سرورهایی که میزبانی مجازی مبتنی بر نام ارائه میدهند، از پروتکل HTTPS استفاده نمود. با این حال راهحلی به نام تشخیص نام سرور[پانویس 20] وجود دارد که نام وبگاه[پانویس 21] را قبل از آغاز رمزگذاری ارسال میکند. این قابلیت در مرورگرهای قدیمی پشتیبانی نمیشود. مرورگر فایرفاکس از نسخهٔ ۲ به بالا، اپرا از نسخهٔ ۸ به بالا، سافاری از نسخهٔ ۲٫۱ به بالا، گوگل کروم از نسخهٔ ۶ به بالا و اینترنت اکسپلورر ۷ به بالا از این قابلیت پشتیبانی میکنند.[45][46]
در کنفرانس کلاهسیاه در سال ۲۰۰۹ یک حملهٔ پیچیده به نام برهنهسازی[پانویس 22] گزارش شد. در این نوع حمله مهاجم با تغییر آدرس از پروتکل "https
" به "http
" کاربر را گمراه میکند. کاربر فکر میکند که ارتباط او امن است، در حالی که مهاجم به راحتی میتواند حملهٔ مرد میانی[پانویس 1] را ترتیب دهد.[47]
در این نوع حمله از این نکته استفاده میشود که اکثر کاربران خودشان قسمت "https://
" را در نوار آدرس تایپ نمیکنند و معمولاً با کلیک بر روی یک لینک به صفحهٔ امن منتقل میشوند.[48]
در ماه مه سال ۲۰۱۰ طبق تحقیقاتی که تیم تحقیقات مایکروسافت با همکاری دانشگاه هند انجام دادند، مشخص شد که بسیاری از اطلاعات حساسی که از طریق HTTPS منتقل میشوند، از طریق روشها و کانالهای جانبی[پانویس 23] مانند مشاهدهٔ حجم بسته، برای مهاجمان قابل دسترسی هستند. بهطور مشخصتر، محققان نشان دادند که با شنود بر روی ارتباطات امن نرمافزارها و وبگاههای بیمارستانها، بانکها و جستجوهای وب میتوانند میزان درآمد، بیماری و نوع آن، داروهای مورد استفاده، عملهای جراحی صورت گرفته بر روی فرد و افراد خانوادهٔ او را تشخیص دهند.[49]
در کنفرانس امنیتی اکوپارتی[پانویس 24] در سال ۲۰۱۱ که در کشور آرژانتین برگزار شد، دو نفر از محققان امنیتی به نامهای جولیانو ریزو[پانویس 25] و ثای دونگ،[پانویس 26] که از توسعهدهندگان مرورگر گوگلکروم نیز میباشند، حملهٔ جدیدی را بر روی HTTPS گزارش دادند. این حمله که از طریق یک حفرهٔ امنیتی و به کمک تکهکد جاوااسکریپت صورت میگیرد، میتواند به مهاجم این امکان را میدهد که متن رمز شده را در یک زمان کوتاه بهطور کامل رمزگشایی کند. این حمله BEAST نام گرفت که مخفف Browser Exploit Against SSL/TLS است.[50][51] این حمله حتی در وبگاههایی که از پروتکل امنیت انتقال سختگیرانهٔ HTTP[پانویس 27] استفاده میکنند قابل اجراست.[52]
این اشکال بر روی SSL نسخهٔ ۳ به پایین و TLS نسخهٔ ۱ که در زمان گزارش حمله در امنیت لایه انتقال پرکاربرد بودند، وجود دارد. در نسخههای بعدی TLS(نسخههای ۱٫۱ و ۲) این مشکل برطرف شد. امروزه مرورگرهای مشهور به صورت پیشفرض نسخههای قدیمی این پروتکلها را غیرفعال میکنند تا از این حمله در امان باشند.[51]
این حمله که مخفف عبارت Compression Ratio Info-leak Made Easy است، در سپتامبر سال ۲۰۱۲ در کنفرانس اکوپارتی[پانویس 24] گزارش شد. در این حمله مهاجم میتواند به کوکیهایی که از طریق HTTPS و پروتکل اسپیدی[پانویس 28] منتقل میشوند، دسترسی پیدا کند. برای جلوگیری از این حمله، کاربران باید پروتکل اسپیدی را در مرورگر خود غیرفعال نمایند.[53]
این حمله نیز توسط جولیانو ریزو[پانویس 25] و ثای دونگ[پانویس 26] گزارش شد.[53]
این حمله که آخرین حملهٔ گزارش شده تاکنون میباشد، در ماه اوت سال ۲۰۱۳، توسط کارشناسان امنیتی گزارش شدهاست. نام این نوع حمله از مخفف کردن عبارت Browser Reconnaissance and Exfiltration via Adaptive Compression of Hypertext گرفته شدهاست. BREACH که به مهاجمان اجازهٔ رمزگشایی بستههای HTTPS را میدهد با عنوان «HTTPS در کمتر از ۳۰ ثانیه هک میشود» در رسانهها بازتاب یافت. تمامی وبگاههایی که از فشردهسازی HTTP[پانویس 29] استفاده میکنند، در برابر این نوع حمله آسیبپذیرند. همچنین اشکالی که از آن استفاده شدهاست در تمامی نسخههای SSL و TLS وجود دارد.[54][55]
تا کنون هیچ راهحلی برای مقابله با این حمله ارائه نشدهاست.[56]
استفاده از پروتکل HTTPS در ایران گاهی دچار مشکل شده و با کاهش سرعت یا قطع دسترسی مواجه میشود.[57][58] بسیاری معتقدند که دلایل این اختلالات، مسائل سیاسی و امنیتی است. مسئولین معمولاً این ادعا را رد میکنند[58] اما وزیر ارتباطات ایران در تیر ماه سال ۱۳۹۲ برای اولین بار اعلام کرد که دلیل افت سرعت اینترنت در زمان پیش از انتخابات، امنیتی و به دلیل انتخابات ریاست جمهوری ایران بودهاست. وی این اقدام را راهکار و ابتکاری در جهت مقابله با ورود بیگانگان به فضای مجازی تعریف کرد.[59]
در ماه اوت سال ۲۰۱۱ میلادی شرکت گوگل اعلام کرد که یکی از گواهیهای دیجیتال این شرکت که در مرجع دیجینوتار[پانویس 30] در کشور هلند ثبت شدهبود، به سرقت رفتهاست. تحقیقات نشان داد که منبع این سرقت کشور ایران بودهاست. با انجام این حمله، مهاجمان توانستند در مقیاسهای بزرگ به ویژه در داخل ایران حملههای مرد میانی و فیشینگ ترتیبدهند. بسیاری ادعا کردند که آیاسپیهای بزرگ در ایران مانند پارسآنلاین و خود دولت با استفاده از این گواهیهای دزدیده شده، از اطلاعات کاربران سوءاستفاده کردند.[60][61]
قابل ذکر است که گواهی دزدیده شده نهتنها مربوط به قسمت جستجوی وبگاه گوگل بود، بلکه در تمامی سرویسهای گوگل از جمله جیمیل، گوگلپلاس و غیره معتبر شناخته میشد. مرورگرهای مشهور با فاصله چند روز از انتشار این خبر، این مرجع را از لیست مراجع مورد تأیید خود حذف کردند. اما این گواهی ۴۰ روز قبل از انتشار این خبر دزدیده شده بود.[60]
کمپانی دیجینوتار بعد از این اتفاق تعطیل شد.[62]
کمپانی نتاسکیپ در سال ۱۹۹۴ میلادی HTTPS را بر پایهٔ اساسال در مرورگر خود(Netscape Navigator) به وجود آورد.[63] ساختار پروتکل بهوجود آمده (اساسال) بهگونهای بود که قابلیت قرار گرفتن هر نرمافزار و سرویسی بر روی آن وجود داشت[64] با گذشت زمان پروتکل اساسال تغییر کرده و جای خود را به امنیت لایه انتقال داد. در واقع نسخهٔ بعد از نسخهٔ ۳٫۰ پروتکل اساسال، امنیت لایه انتقال نامیدهشد. به همین دلیل عدهای این پروتکل را اساسال نسخهٔ ۳٫۱ نیز مینامند.[65] نسخههای بعدی پروتکل امنیت لایه انتقال با ایجاد تغییرات بزرگ، راه خود را از اساسال جدا کردند.[66] در نسخهٔ فعلی HTTPS که در ماه مه سال ۲۰۰۰ میلادی در RFC 2818 معرفی شدهاست، امنیت لایه انتقال بهعنوان جایگزین پروتکل اساسال، در لایهٔ زیرین HTTPS قرار گرفتهاست.
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.