ایمپلنت‌های نامرئی در کد منبع

02 آذر 1400 ایمپلنت‌های نامرئی در کد منبع

روابط عمومی شرکت ایدکو (توزیع‌کننده‌ی محصولات کسپرسکی در ایران)؛ متخصصین دانشگاه کمبریج آسیب‌پذیری‌ای را شرح دادند که به گفته آن‌ها بیشتر کامپایلرهای مدرن را تحت‌الشعاع قرار داده است. یک شیوه حمله جدید و بکر از قابلیت قانونی ابزارهای توسعه استفاده می‌کند و بموجب این ترفند، کد منبع یک چیز نشان می‌دهد اما چیزی کاملاً متفاوت را کامپایل می‌کند. این جادوی کاراکترهای کنترل Unicode است.

بیشتر وقت‌ها کاراکترهای کنترل روی صفحه با بقیه کد ظاهر نمی‌شوند (هرچند برخی ادیتورها آن‌ها را نمایش می‌دهد) اما به طریقی متن را دستکاری می‌کنند. در این جدول کدهایی را مشاهده می‌کنید حاوی بعنوان مثال الگوریتم دوجهته‌ی Unicode[1]. همانطور که احتمالاً می‌دانید برخی زبان‌هایی که انسان‌ها استفاده می‌کنند از چپ به راست است (مانند انگلیسی) و بقیه نیز از راست به چپ (مثل عربی). وقتی کدی فقط حاوی یک زبان باشد مشکلی نیست اما در صورت لزوم -وقتی برای مثال یک خط دارای لغاتی هم به انگلیسی و هم به عربی باشد- کدهای bidi (دو جهته) مسیر و جهت متن را تعیین می‌کنند. محققین از چنین کدهایی برای مثال جهت حرکت دادن ترمیناتورِ کامنت از کد پایتون[2] استفاده کردند (از وسط خط به آخر خط). آن‌ها برای تغییر چند کاراکتر از کد RLI استفاده کردند و بقیه چیزها را دست‌نخورده باقی گذاشتند.

در بخش راست نسخه‌ای وجود دارد که برنامه‌نویسان موقع چک کردن کد منبع آن را می‌بینند؛ سمت چپ هم نشان می‌دهد چطور کد اجرا خواهد شد. بیشتر کامپایلرها کاراکترهای کنترل را نادیده می‌گیرند. هر کسی که کد را چک می‌کند با خود فکر خواهد کرد خط پنجم یک کامنت بی‌خطر است اما در باطن یک جمله مخفی‌شده داخلش بزودی باعث خواهد شد برنامه عملیات را رد کرده و نادیده‌اش بگیرد؛ عملیاتی که کارش درآوردن پول از حساب بانکی است. در این نمونه –به بیانی دیگر- برنامه بانکی شبیه‌سازی‌شده پول را توزیع می‌کند اما موجودی حساب را کم نمی‌کند.

چرا باید از این آسیب‌پذیری ترسید؟

در اولین نگاه، این آسیب‌پذیری به نظر ساده می‌آید. چه کسی می‌آید کاراکترهای نامرئی را درج کند و امید داشته باشد ممیزگرهای کد منبع فریب بخورند؟ با این حال مشکل آنقدری جدی تلقی شده بود که یک شناسه آسیب‌پذیری تضمین شود (CVE-2021-42574). پیش از نشر این مقاله، نویسندگان در مورد رایج‌ترین کامپایلرها به توسعه‌دهندگان اطلاع دادند و به آن‌ها زمانی دادند برای آماده کردن یک سری پچ.

این آسیب‌پذیری تا چه میزان خطرناک است؟

کمی بعد از نشر این مقاله رای کاکسِ برنامه‌نویس حمله  Trojan Source را مورد انتقاد قرار داد. او در حقیقت تحت‌تأثیر قرار نگرفت. در ادامه بخش‌هایی از صحبت‌های او را خواهیم داشت:

  •         این اصلاً حمله‌ی جدیدی نیست.
  •         بسیاری از ادیتورهای کد برای نمایش کد نامرئی از برجسته‌سازی نحوی استفاده می‌کنند.
  •         پچ‌های کامپایلرها لازم نیستند- همین که با دقت کد چک شود تا مبادا در آن باگ‌های آلوده یا تصادفی وجود داشته باشد کفایت می‌کند.

در واقع مشکلی که اکنون با کاراکترهای کنترل Unicode پیدا شده است ریشه در سال 2017 دارد.  همچنین مشکل مشابهی هم با هموگلیف‌ها[3] -کاراکترهایی که یک‌جور به نظر می‌رسند اما کدهای مختلفی دارند- پیش آمده که آن هم چندان جدید نیست و کارش پنهان کردن کدهای اضافی برای عبورد دادنشان‌های از بازرسی‌های دستی است. با این حال تحلیل انتقادیِ کاکس موجودیت این چالش را انکار نمی‌کند، بلکه گزارشاتی را که در آن‌ها از بار دراماتیک بسیاری استفاده شده بود محکوم می‌کند- برای مثال توصیف نامناسب روزنامه‌نگار برایان کرب از باگ Trojan Source که می‌گفت امنیت کل کد را به خطر می‌اندازد. مشکل، واقعی است اما خوشبختانه راهکار حل آن بسیار ساده است. همه پچ‌هایی که تا به حال نشر شدند یا قرار است بزودی نشر شوند کامپایل کردن کدهای حاوی چنین کاراکترهایی را بلاک خواهند کرد. اگر از ابزارهای ساخت نرم‌افزاری مخصوص به خود استفاده می‌کنید توصیه می‌کنیم برای کاراکترهای مخفی که نباید به طور نرمال در کد منبع ظاهر شوند یک چک مشابه اضافه کنید.

خطر حملات زنجیره تأمین

بسیاری از شرکت‌ها تسک‌های توسعه را برای کنتراکتورها برون‌سپاری می‌کنند و یا از ماژول‌های منبع باز از پیش آماده در پروژه‌های خود استفاده می‌نمایند. این کار همیشه دری را به روی ورود حملات زنجیره تأمین باز می‌کند. مجرمان سایبری می‌توانند یک کنتراکتور را دستکاری کرده و یا در یک پروژه‌ی منبع باز کدی را جاساز کنند و در ادامه کد مخرب را در نسخه نهایی نرم‌افزار بگنجانند. ممیزی‌های کد معمولاً چنین بک‌درهایی را برملا می‌کنند اما اگر نکردند، کاربران نهایی ممکن است نرم‌افزار را از منابع قابل‌اطمینان دریافت کنند اما هنوز داده‌های خود را از دست داده باشند. Trojan Source نمونه‌ی دیگریست از حمله‌ای به مراتب باشکوه‌تر. مهاجمین به جای اینکه سعی کنند مگابایت‌های کد مخرب را در محصولی نهایی قاچاق کنند می‌توانند از چنین رویکردی برای معرفی ایمپلنتی که بسختی شناسایی می‌شود در بخش مهمی از یک نرم‌افزار استفاده کرده و آن را تا سال‌های آتی همچنان اکسپلویت کنند.

راهکارهای امنیتی

  •         همه کامپایلرهای زبان برنامه‌نویسی را که استفاده می‌نمایید آپدیت کنید (اگر برایشان پچی ارائه شده است)
  •         اسکریپت‌های خود را بنویسید؛ که دامنه محدودی از کاراکترهای کنترل را در کد منبع شناسایی کند.

مبارزه در برابر حملات بالقوه‌ی زنجیره تأمین نیازمند ممیزی‌های دستی کد و نیز دامنه‌ای از تست‌های اتومات است. دیدن کد خودتان از دریچه نگاه مجرمان سایبری هرگز ضرری نداشته و نخواهد داشت. سعی کنید یک ارور ساده را هدف بگیرید؛ اروری که می‌تواند کل مکانیزم امنیتی را به هم بریزد. اگر برای چنین نوع تحلیلی منابع لوکال کافی ندارید از متخصصین خارجی کمک بگیرید.

 

 

[1] Unicode Bidirectional (bidi) Algorithm

[2] Python code

[3] homoglyphs

 

منبع: کسپرسکی آنلاین (ایدکو)

کسپرسکی اسم یکی از بزرگترین شرکتهای امنیتی و سازنده آنتی ویروس است که برخی از کاربران اشتباهاً این شرکت و محصولات آنتی ویروس آن را با عناوینی نظیر کسپرسکای،کاسپرسکی، کسپراسکای، کسپراسکای، و یا کاسپراسکای نیز می‌شناسد. همچنین لازم به ذکر است مدیرعامل این شرکت نیز یوجین کسپرسکی نام دارد.

محصولات مرتبط

  • Kaspersky Internet Security for Android

    امنیت پیشرفته‌ای که همیشه همراه شماست بخش مهمی از زندگی اکثر ما اکنون روی گوشی‌ها و تبلت‌هاست- پس به امنیت موبایلی نیاز دارید که شما را همیشه امن نگه ...

    11,224,300 ریال
    خرید
  • Kaspersky Cloud Password Manager

    Kaspersky Cloud Password Manager ابزار مدیریت کلمه عبور ابری کسپرسکی (KCPM) ضمن ذخیره ایمن تمامی کلمات عبور مورد استفاده شما برای وبسایت‌ها، اپلیکیشن‌ها، و شبکه‌های اجتماعی آنها را در تمامی ...

    16,841,800 ریال
    خرید
  • Kaspersky Safe Kids

    اپلیکیشن همه‌کاره برای فرزندپروریِ دیجیتال و سلامت خانواده نرم افزار امنیت کودکان کسپرسکی، نظارت‌های والدین را آسان می‌کند. ردیابی مکان و عادات دستگاه، محدودسازی محتوا، متعادل‌سازی ...

    8,420,900 ریال16,841,800 ریال
    خرید
  • Kaspersky Security Cloud Personal

    تمام اپ‌های امنیتیِ ما در دستانتان. به کل خانواده‌ی اپ‌های ما برای دسکتاپ و موبایل دسترسی پیدا کنید. از آنتی‌ویروس گرفته تا ابزارهای حریم خصوصی و اجرایی، هر کدام را به میل ...

    112,339,300 ریال
    خرید
  • Kaspersky Standard

    سیستم امنیتی بهبودیافته به همراه تقویت‌کننده عمکرد دستگاه طرح امنیتی استاندارد ما، نه تنها سیستم امنیتی قدرتمندی را برای انواع ویروس‌ها، بدفزارها و باج‌افزارها ارائه می‌دهد ...

    15,889,500 ریال31,779,000 ریال
    خرید
  • Kaspersky Plus

    امنیت. کارایی. حریم خصوصی. همه در یک برنامه با کاربری آسان کسپرسکی پلاس با ارائه امنیت سایبری نسل بعد، شما در برابر ویروس‌ها، باج‌افزارها و بدافزارهای جدید محافظت کند - بدون ...

    22,785,650 ریال45,571,300 ریال
    خرید
  • Kaspersky Premium

    حفاظت کامل از دستگاه ها، حریم خصوصی و هویت شما با محصول Kaspersky Premium تمام نیازهای امنیتی خود و خانواده‌تان را پوشش دهید. حفاظت پیشرفته ...

    24,374,600 ریال48,749,200 ریال
    خرید
  • Kaspersky Small Office Security

    محافظت در حین کار Kaspersky Small Office Security به طور خاص برای سازمان‌هایی طراحی شده است که 5 تا 50 دستگاه کامپیوتر در خود جای داده‌اند. نصب آن بسیار آسان است؛ مدیریت آن ...

    101,109,650 ریال202,219,300 ریال
    خرید
  • Kaspersky Small Office Security

    امنیت ادارات کوچک

    323,557,300 ریال
    خرید
  • Kaspersky Small Office Security

    امنیت ادارات کوچک

    121,332,650 ریال242,665,300 ریال
    خرید
  • Kaspersky Small Office Security

    388,720,300 ریال
    خرید
  • Kaspersky Small Office Security

    141,555,650 ریال283,111,300 ریال
    خرید
  • Kaspersky Small Office Security

    452,759,800 ریال
    خرید
  • Kaspersky Small Office Security

    161,778,650 ریال323,557,300 ریال
    خرید
  • Kaspersky Small Office Security

    517,922,800 ریال
    خرید
  • Kaspersky Small Office Security

    182,001,650 ریال364,003,300 ریال
    خرید
  • Kaspersky Small Office Security

    581,962,300 ریال
    خرید
  • Kaspersky Small Office Security

    185,372,150 ریال370,744,300 ریال
    خرید
  • Kaspersky Small Office Security

    593,197,300 ریال
    خرید
  • Kaspersky Small Office Security

    261,208,400 ریال522,416,800 ریال
    خرید
  • Kaspersky Small Office Security

    835,873,300 ریال
    خرید
  • Kaspersky Small Office Security

    337,044,650 ریال674,089,300 ریال
    خرید
  • Kaspersky Small Office Security

    1,078,549,300 ریال
    خرید
  • Kaspersky Small Office Security

    407,263,400 ریال814,526,800 ریال
    خرید
  • Kaspersky Small Office Security

    1,303,249,300 ریال
    خرید
  • Kaspersky Small Office Security

    772,400,900 ریال1,544,801,800 ریال
    خرید
  • Kaspersky Small Office Security

    2,471,689,300 ریال
    خرید
  • Kaspersky Endpoint Security for Business Select

    حفظ امنیت داده‌ها، سیستم‌ها، و نیروهای کاری سیار ضدبدافزار چندلایه که برنده جایزه شده است کنترل‌گرهای اندپوینت-برنامه، ابزار و وب امنیت ...

    471,870,000 ریال
    خرید
  • Kaspersky Endpoint Security for Business Select

    Kaspersky Endpoint Security for Business Select

    631,974,100 ریال
    خرید
  • Kaspersky Endpoint Security for Business Select

    Kaspersky Endpoint Security for Business Select

    763,980,000 ریال
    خرید
  • Kaspersky Endpoint Security for Business Select

    Kaspersky Endpoint Security for Business Select

    856,674,100 ریال
    خرید
  • Kaspersky Endpoint Security for Business Select

    Kaspersky Endpoint Security for Business Select

    1,544,812,500 ریال
    خرید
  • Kaspersky Endpoint Security for Business Select

    Kaspersky Endpoint Security for Business Select

    2,808,750,000 ریال
    خرید
  • Kaspersky Endpoint Security for Business Advanced

    ارتقا امنیت و کارایی فناوری اطلاعات در محیط کاری شما کنترل‌های نهایی ضدبدافزار و رمزیابی داده مدیریت پچ و مدیریت فناوری اطلاعات و ابزارهای کارآمد ...

    662,865,000 ریال
    خرید
  • Kaspersky Endpoint Security for Business Advanced

    Kaspersky Endpoint Security for Business Advanced

    893,182,500 ریال
    خرید
  • Kaspersky Endpoint Security for Business Advanced

    Kaspersky Endpoint Security for Business Advanced

    1,067,325,000 ریال
    خرید
  • Kaspersky Endpoint Security for Business Advanced

    Kaspersky Endpoint Security for Business Advanced

    1,207,762,500 ریال
    خرید
  • Kaspersky Endpoint Security for Business Advanced

    Kaspersky Endpoint Security for Business Advanced

    2,162,737,500 ریال
    خرید
  • Kaspersky Endpoint Security for Business Advanced

    Kaspersky Endpoint Security for Business Advanced

    3,932,250,000 ریال
    خرید
  • Kaspersky Total Security for Business

    راهکار نهایی مدیریت سیستم‌ها و امنیت ضدبدافزار، کنترل‌گرها، رمزنگاری و امنیت سیار مدیریت پچ و اسکن خودکار آسیب‌پذیری‌ها کارکرد مدیریت ...

    1,123,500,000 ریال
    خرید
  • Kaspersky Total Security for Business

    Kaspersky Total Security for Business

    1,508,304,100 ریال
    خرید
  • Kaspersky Total Security for Business

    Kaspersky Total Security for Business

    1,808,835,000 ریال
    خرید
  • Kaspersky Total Security for Business

    Kaspersky Total Security for Business

    2,050,387,500 ریال
    خرید
  • Kaspersky Total Security for Business

    Kaspersky Total Security for Business

    3,651,375,000 ریال
    خرید
  • Kaspersky Total Security for Business

    Kaspersky Total Security for Business

    6,684,825,000 ریال
    خرید
  • Kaspersky Internet Security for Android

    تضمین امنیت اسمارت فون ها و تبلت ها؛ فقط با یک محصول Kaspersky Security for Android قادر است از ابزارهاي اندرويدي و اطلاعات شخصي ذخيره ...

    16,841,800 ریال
    خرید
  • Kaspersky Standard

    کسپرسکی استاندارد

    63,568,700 ریال
    خرید
  • Kaspersky Standard

    کسپرسکی استاندارد

    18,543,100 ریال37,086,200 ریال
    خرید
  • Kaspersky Standard

    کسپرسکی استاندارد

    74,172,400 ریال
    خرید
  • Kaspersky Standard

    کسپرسکی استاندارد

    20,661,700 ریال41,323,400 ریال
    خرید
  • Kaspersky Standard

    کسپرسکی استاندارد

    82,657,500 ریال
    خرید
  • Kaspersky Standard

    کسپرسکی استاندارد

    54,045,700 ریال
    خرید
  • Kaspersky Standard

    کسپرسکی استاندارد

    108,070,000 ریال
    خرید
  • Kaspersky Plus

    کسپرسکی پلاس

    91,131,900 ریال
    خرید
  • Kaspersky Plus

    کسپرسکی پلاس

    24,904,250 ریال49,808,500 ریال
    خرید
  • Kaspersky Plus

    کسپرسکی پلاس

    110,199,300 ریال
    خرید
  • Kaspersky Plus

    کسپرسکی پلاس

    27,552,500 ریال55,105,000 ریال
    خرید
  • Kaspersky Plus

    کسپرسکی پلاس

    110,199,300 ریال
    خرید
  • Kaspersky Plus

    کسپرسکی پلاس

    66,757,300 ریال
    خرید
  • Kaspersky Plus

    کسپرسکی پلاس

    133,525,300 ریال
    خرید
  • Kaspersky Premium

    کسپرسکی پریمیوم

    27,022,850 ریال54,045,700 ریال
    خرید
  • Kaspersky Premium

    کسپرسکی پریمیوم

    29,141,450 ریال58,282,900 ریال
    خرید
  • Kaspersky Premium

    کسپرسکی پریمیوم

    69,935,200 ریال
    خرید
  • Kaspersky Premium

    کسپرسکی پریمیوم

    93,261,200 ریال
    خرید

نظر خودتان را ارسال کنید


کاربر گرامی چنانچه تمایل دارید، نقد یا نظر شما به نام خودتان در سایت ثبت شود، لطفاً وارد سایت شوید.
*نظر
کلیه حقوق مادی و معنوی این سایت محفوظ و متعلق به شرکت گسترش خدمات تجارت الکترونیک ایرانیان است و هر گونه کپی برداری از آن پیگرد قانونی دارد