ویرگول
ورودثبت نام
rasgari
rasgariدر مورد ای‌تی، کار، روزمرگی و زندگی می‌نویسم | کارشناس تست نفوذ وب | گیت هاب https://github.com/rasgari
rasgari
rasgari
خواندن ۵ دقیقه·۱۶ روز پیش

ترفند و تکنیک های کلیدی یک باگ هانتر

بررسی ترفندها و تکنیک‌های کلیدی که یک باگ هانتر (Bug Hunter) برای یافتن آسیب‌پذیری‌ها به کار می‌برد:

ترفندهای باگ هانتر: گشت‌وگذار در دنیای آسیب‌پذیری‌ها

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

۱. درک عمیق از معماری و منطق برنامه (Deep Understanding of Architecture & Logic)

قبل از هر چیز، یک باگ هانتر باید سعی کند تا حد امکان درک جامعی از نحوه کارکرد برنامه، معماری آن، فناوری‌های به کار رفته (مانند زبان برنامه‌نویسی، فریم‌ورک‌ها، پایگاه داده) و منطق تجاری (Business Logic) آن به دست آورد. این شامل موارد زیر است:

نقشه‌برداری از برنامه (Mapping the Application): شناسایی تمام نقاط ورودی (Endpoints)، صفحات، پارامترها، درخواست‌ها و پاسخ‌های احتمالی. ابزارهایی مانند Burp Suite یا OWASP ZAP در این مرحله بسیار مفید هستند.

شناسایی جریان داده (Data Flow Analysis): درک اینکه داده‌ها چگونه وارد برنامه می‌شوند، کجا ذخیره یا پردازش می‌شوند و چگونه از آن خارج می‌شوند. این به شناسایی نقاطی که داده‌ها ممکن است به درستی اعتبارسنجی (Sanitize) نشوند، کمک می‌کند.

بررسی منطق تجاری: درک اینکه برنامه چگونه وظایف اصلی خود را انجام می‌دهد. گاهی اوقات، آسیب‌پذیری‌ها از سوءاستفاده از منطق غیرمنتظره یا نقاط کور در فرآیندهای تجاری ناشی می‌شوند.


۲. تکنیک‌های تست نفوذ رایج (Common Penetration Testing Techniques)

بسیاری از آسیب‌پذیری‌های شناخته شده از طریق اعمال تکنیک‌های استاندارد تست نفوذ قابل کشف هستند. این تکنیک‌ها پایه‌های کار باگ هانترها را تشکیل می‌دهند:

تزریق (Injection): این دسته شامل انواع مختلفی از حملات تزریق است که در آن داده‌های مخرب به برنامه ارسال می‌شود تا رفتار آن را تغییر دهد. معروف‌ترین آن‌ها عبارتند از:

SQL Injection (SQLi): تزریق دستورات SQL به ورودی‌های برنامه برای دستکاری یا استخراج داده‌ها از پایگاه داده.

Cross-Site Scripting (XSS): تزریق اسکریپت‌های مخرب (معمولاً جاوا اسکریپت) به صفحات وب که سپس در مرورگر سایر کاربران اجرا می‌شود. انواع آن شامل Stored XSS، Reflected XSS و DOM-based XSS است.

Command Injection: تزریق دستورات سیستم عامل به ورودی‌هایی که توسط برنامه اجرا می‌شوند.

LDAP Injection, NoSQL Injection: انواع مشابه تزریق برای پروتکل‌ها و پایگاه‌های داده دیگر.

شکستن احراز هویت و مدیریت نشست (Broken Authentication & Session Management):

Credential Stuffing: استفاده از لیست نام‌های کاربری و رمزهای عبور لو رفته از سایر سایت‌ها.

Brute-Force Attacks: امتحان کردن تمام ترکیب‌های ممکن برای رمز عبور یا نام کاربری.

Session Fixation: وادار کردن کاربر به استفاده از یک شناسه نشست (Session ID) که توسط مهاجم کنترل می‌شود.

Weak Session ID Generation: تولید شناسه‌های نشست قابل پیش‌بینی.

مدیریت نامناسب دسترسی (Insecure Access Control):

Vertical Privilege Escalation: کاربری با سطح دسترسی پایین‌تر، قادر به انجام عملیات مختص کاربران با سطح دسترسی بالاتر شود (مثلاً یک کاربر عادی به پنل ادمین دسترسی پیدا کند).

Horizontal Privilege Escalation: کاربری بتواند به داده‌ها یا عملکردهای سایر کاربران در همان سطح دسترسی دسترسی پیدا کند (مثلاً از حساب کاربری A به حساب کاربری B دسترسی یابد).

Forced Browsing: دسترسی مستقیم به صفحات یا APIهایی که نباید از طریق رابط کاربری قابل دسترس باشند.

پیکربندی امنیتی نادرست (Security Misconfiguration):

استفاده از تنظیمات پیش‌فرض ناامن: رها کردن تنظیمات پیش‌فرض سرورها، فریم‌ورک‌ها یا برنامه‌ها.

نمایش پیام‌های خطا یا اطلاعات حساس: افشای جزئیات فنی در پیام‌های خطا.

پوشه‌های باز (Open Directories): امکان مشاهده لیست فایل‌ها در یک پوشه از طریق وب.

پروتکل‌های ناامن: استفاده از HTTP به جای HTTPS، یا FTP به جای SFTP.

آسیب‌پذیری‌های مرتبط با اجزای نرم‌افزاری (Using Components with Known Vulnerabilities): استفاده از کتابخانه‌ها، فریم‌ورک‌ها یا ماژول‌های قدیمی و دارای آسیب‌پذیری‌های شناخته شده (CVE). ابزارهایی مانند OWASP Dependency-Check یا Snyk در این زمینه کمک می‌کنند.

عدم اعتبارسنجی داده‌ها (Improper Data Validation): عدم بررسی دقیق و کافی ورودی‌ها و خروجی‌ها، که می‌تواند منجر به حملات مختلفی مانند XSS، SQLi و … شود.


۳. تکنیک‌های پیشرفته و خلاقانه (Advanced & Creative Techniques)

فراتر از تکنیک‌های استاندارد، باگ هانترهای باتجربه از رویکردهای خلاقانه‌تری استفاده می‌کنند:

مهندسی معکوس (Reverse Engineering): درک کدهای منبع (در صورت دسترسی) یا تحلیل باینری‌ها و ترافیک شبکه برای فهم عمیق‌تر نحوه عملکرد برنامه.

فازینگ (Fuzzing): ارسال حجم عظیمی از داده‌های تصادفی، نامعتبر یا غیرمنتظره به ورودی‌های برنامه برای یافتن کرش‌ها یا رفتارهای غیرعادی که ممکن است نشان‌دهنده آسیب‌پذیری باشند.

تکنیک‌های خاص API: تمرکز بر آسیب‌پذیری‌های رایج در APIها مانند Mass Assignment، Broken Object Level Authorization (BOLA)، Broken Function Level Authorization (BFLA) و …

تحلیل وضعیت‌های مرزی (Edge Case Analysis): بررسی رفتارهای برنامه در شرایط غیرمعمول، مانند ورودی‌های بسیار طولانی، کاراکترهای خاص، یا ترکیب‌های پیچیده از پارامترها.

تست مجدد پس از تغییرات (Re-testing after Changes): درک اینکه چگونه تغییرات و به‌روزرسانی‌های جدید در برنامه ممکن است آسیب‌پذیری‌های جدیدی ایجاد کنند یا آسیب‌پذیری‌های قدیمی را برطرف کنند.

جستجوی پاداش باگ (Bug Bounty Hunting): استفاده از پلتفرم‌های باگ بانتی (مانند HackerOne، Bugcrowd) برای یافتن برنامه‌هایی که پاداش برای گزارش آسیب‌پذیری پرداخت می‌کنند. این خود یک رویکرد استراتژیک است.

استفاده از ابزارهای اتوماسیون و اسکریپت‌نویسی: نوشتن اسکریپت‌های سفارشی برای خودکارسازی وظایف تکراری یا تست سناریوهای خاص.


۴. ذهنیت و نگرش (Mindset & Attitude)

مهم‌تر از همه، نگرش یک باگ هانتر است:

کنجکاوی سیری‌ناپذیر: همیشه سوال “اگر این کار را بکنم چه می‌شود؟” در ذهنشان باشد.

پشتکار و عدم تسلیم: بسیاری از آسیب‌پذیری‌ها با اولین تلاش‌ها پیدا نمی‌شوند.

تفکر خارج از چارچوب: سعی در یافتن راه‌های غیرمنتظره برای تعامل با برنامه.

اخلاق حرفه‌ای: گزارش صادقانه و مسئولانه آسیب‌پذیری‌ها.

در نهایت، باگ هانتر موفق کسی است که ترکیبی از دانش فنی، ابزارهای مناسب و مهم‌تر از همه، یک ذهنیت جستجوگر و خلاق را به کار می‌گیرد تا سیستم‌ها را امن‌تر کند.

تست نفوذباگ بانتی
۶
۴
rasgari
rasgari
در مورد ای‌تی، کار، روزمرگی و زندگی می‌نویسم | کارشناس تست نفوذ وب | گیت هاب https://github.com/rasgari
شاید از این پست‌ها خوشتان بیاید