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

باگهای امنیتی در مقابل حمله به وردپرس
1. پایگاه داده SQL (SQL Injection)
تزریق SQL مخرب یک نوع حمله امنیتی است که در آن هکرها کدهای مخرب SQL را وارد ورودیهای یک وبسایت میکنند تا به دیتابیس آن دسترسی پیدا کنند یا آن را تغییر دهند. این نوع حمله میتواند منجر به دسترسی غیرمجاز به اطلاعات حساس، تغییر دادهها، یا حتی حذف دادهها شود.
اگر وردپرس به درستی امن نشده باشد، هکرها میتوانند از نقاط ضعف موجود در پلاگینها، قالبها یا خود هسته وردپرس استفاده کنند تا کدهای مخرب SQL را تزریق کنند. این حملات معمولاً از طریق فرمهای ورودی، URLها، یا دیگر نقاط ورود دادهها انجام میشود.
2. حملات XSS (Cross-Site Scripting)
حملات XSS به مهاجم اجازه میدهد که اسکریپتهای مخرب را به صفحات وب اضافه کند که میتواند اطلاعات کاربران را سرقت کند یا آنها را به سایتهای مخرب هدایت کند. هکرها میتوانند از طریق URLها و پارامترهای GET کدهای مخرب را به صفحات وب تزریق کنند.
3. حملات CSRF (Cross-Site Request Forgery)
این نوع حمله زمانی رخ میدهد که یک کاربر قربانی درخواستهای ناخواستهای را به یک وبسایت ارسال میکند که در آن به صورت آنلاین لاگین کرده است. این حملات میتواند منجر به تغییر تنظیمات کاربر یا انجام عملیاتهای مخرب بدون اطلاع کاربر شود.
4. افشای اطلاعات
باگها یا پیکربندیهای نادرست میتواند به افشای اطلاعات حساس منجر شود، از جمله نشتی دادههای کاربران یا اطلاعات پیکربندی سرور.
5. بروت فورس Brute Force Attacks
اگرچه این نوع حمله به طور مستقیم به یک باگ امنیتی مربوط نمیشود، ولی ضعف در سیاستهای رمز عبور میتواند این نوع حملات را تسهیل کند.
انواع حمله به وردپرس
حملات DDOS (دیداس) به وبسایتهای وردپرسی معمولاً به دلیل ضعفهای امنیتی خاصی در وردپرس نیستند، بلکه به خاطر طبیعت باز و گستردهی استفاده از وردپرس و نحوهی پیکربندی آن توسط مدیران وبسایتها اتفاق میافتند. حملات DDOS به وبسایتهای وردپرسی میتوانند از طریق چندین روش صورت گیرند، اما بیشتر شامل موارد زیر هستند:
1. حملات به لایه برنامه کاربردی
این نوع حملات مستقیماً به بخشهای خاصی از وبسایت مانند فرمهای ورود، صفحات جستجو، یا APIها هدف گرفته میشوند. آنها با ارسال درخواستهای متعدد و سنگین به این بخشها در تلاش برای فرسوده کردن منابع سرور و کاهش عملکرد وبسایت هستند.
2. حملات به سطح شبکه
این حملات با هدف قرار دادن زیرساختهای شبکه و ارتباطات، از جمله ارسال ترافیک سنگین به سرورها برای اشباع پهنای باند و ایجاد اختلال در دسترسی کاربران انجام میشوند.
راههای جلوگیری از حمله به وردپرس
برای جلوگیری از حملات سایبری در سایتهای وردپرسی، میتوانید از اقدامات امنیتی و کدهای مختلف استفاده کنید. در اینجا چند نمونه از کدها و تنظیماتی که میتواند به افزایش امنیت سایت وردپرسی شما کمک کند، ارائه میدهیم:
1. محدود کردن تلاشهای ناموفق ورود
حملات نیروی خام (Brute Force) یکی از روشهای رایج حمله به سیستمهای رایانهای و وبسایتها است که در آن مهاجم با استفاده از آزمون و خطا تلاش میکند تا رمز عبور یا کلید رمزنگاری را کشف کند. در این نوع حملات، مهاجم به طور سیستماتیک تمامی ترکیبهای ممکن از کاراکترها را آزمایش میکند تا به نتیجه درست برسد. این روش به دلیل نیاز به منابع محاسباتی بالا و زمان طولانی، معمولاً توسط ابزارهای خودکار انجام میشود. در وبسایتهای وردپرسی، حملات نیروی خام معمولاً بر روی صفحه ورود (wp-login.php) و فرمهای ورود به سیستم انجام میشود. مهاجم با استفاده از یک اسکریپت خودکار سعی میکند ترکیبهای مختلف نام کاربری و رمز عبور را امتحان کند تا به حساب کاربری مدیر یا سایر کاربران دسترسی پیدا کند. این کار را میتوانید با نصب افزونههایی مانند Limit Login Attempts Reloaded انجام دهید.

2. غیرفعال کردن اجرای PHP در پوشههای بارگذاری
اجرای فایلهای PHP در پوشههای بارگذاری میتواند یک ریسک امنیتی باشد. برای جلوگیری از این کار، کد زیر را در فایل .htaccess در پوشهی wp-content/uploads/ قرار دهید:

تگ <Files *.php> مشخص میکند که این قوانین برای تمامی فایلهای با پسوند .php اعمال شود.
دستور deny from all دسترسی به این فایلها را از همه کاربران منع میکند. با افزودن این کد به فایل .htaccess در پوشهی wp-content/uploads/، اجرای فایلهای PHP در این پوشه غیرفعال خواهد شد و از بروز مشکلات امنیتی جلوگیری میشود. این اقدام یک راه ساده و موثر برای افزایش امنیت وبسایت وردپرسی شما است.
3. تغییر پیشوند جدولهای پایگاه داده
حملات SQL Injection میتوانند از پیشوندهای پیشفرض جدول پایگاه داده wp_ سوء استفاده کنند. برای افزایش امنیت، پیشوند جدولها را به هنگام نصب وردپرس یا با استفاده از افزونههایی مانند “Change Table Prefix” تغییر دهید.
4. محافظت از فایل wp-config.php
فایل wp-config.php یکی از مهمترین فایلهای وردپرس است که اطلاعات حساسی را در خود نگهداری میکند. برای محافظت از آن، کد زیر را به فایل .htaccess اضافه کنید:

تگ <files wp-config.php> مشخص میکند که این قوانین برای فایل wp-config.php اعمال شود.
دستور order allow,deny مشخص میکند که ابتدا دسترسی مجاز تعیین شود و سپس دسترسی غیرمجاز اعمال شود.
دستور deny from all تمامی درخواستها برای دسترسی به فایل wp-config.php را مسدود میکند.
با افزودن این کد به فایل .htaccess، میتوانید دسترسی غیرمجاز به فایل wp-config.php را مسدود کرده و از اطلاعات حساس سایت خود محافظت کنید. این یک اقدام ساده ولی موثر برای افزایش امنیت وبسایت وردپرسی شما است.
5. غیرفعال کردن اجرای XML-RPC
XML-RPC میتواند برای حملات Brute Force مورد استفاده قرار گیرد. برای غیرفعال کردن آن، کد زیر را به فایل .htaccess اضافه کنید:

تگ <Files xmlrpc.php> مشخص میکند که این قوانین برای فایل xmlrpc.php اعمال شود.
دستور order deny,allow مشخص میکند که ابتدا دسترسی غیرمجاز تعیین شود و سپس دسترسی مجاز اعمال شود.
دستور deny from all تمامی درخواستها برای دسترسی به فایل xmlrpc.php را مسدود میکند.
با افزودن این کد به فایل .htaccess، میتوانید دسترسی غیرمجاز به فایل xmlrpc.php را مسدود کرده و از حملات نیروی خام (Brute Force) جلوگیری کنید. این اقدام یک راه ساده و موثر برای افزایش امنیت وبسایت وردپرسی شما است.
6. بهروزرسانی منظم وردپرس، افزونهها، و قالبها
اطمینان از اینکه وردپرس، افزونهها و قالبهای شما همیشه بهروز هستند، یکی از مهمترین اقدامات امنیتی است. همچنین، استفاده از افزونههای امنیتی معتبر میتواند به شما کمک کند تا سایت خود را در برابر حملات مختلف محافظت نمایید.
7. اجبار به استفاده از HTTPS
برای حفظ امنیت اطلاعات کاربران و افزایش امنیت وبسایت، استفاده از HTTPS ضروری است. HTTPS (HyperText Transfer Protocol Secure) رمزنگاری دادهها را بین مرورگر کاربران و سرور وبسایت فراهم میکند، که به جلوگیری از شنود و حملات مرد میانی (Man-in-the-Middle) کمک میکند.برای حفظ امنیت اطلاعات کاربران و افزایش امنیت وبسایت، استفاده از HTTPS ضروری است. اطمینان حاصل کنید که وبسایت شما از گواهی SSL استفاده میکند و ترافیک را به HTTPS اجبار میکند.
ابتدا یک گواهی SSL معتبر از یک ارائهدهنده گواهی دریافت کنید.
گواهی را بر روی سرور خود نصب کنید. بسیاری از میزبانهای وب این فرایند را به صورت خودکار انجام میدهند و میتوانید با پشتیبانی فنی میزبان خود تماس بگیرید.

8. استفاده از افزونههای امنیتی
افزونههای امنیتی معتبر مانند Wordfence، iThemes Security، یا Sucuri Security میتوانند لایههای اضافی امنیتی ارائه دهند و به شناسایی و جلوگیری از تلاشهای نفوذ کمک کنند.
این توصیهها و کدها میتوانند به عنوان بخشی از استراتژی امنیتی جامع شما برای محافظت از سایت وردپرسی در برابر حملات سایبری استفاده شوند.

9. میزبانی اختصاصی Dedicated Hosting
میزبانی اختصاصی (Dedicated Hosting) یکی از گزینههای میزبانی وب است که در آن یک سرور فیزیکی به صورت کامل به یک وبسایت یا مجموعهای از وبسایتها اختصاص داده میشود. این نوع میزبانی مزایای زیادی دارد که میتواند به طور قابل توجهی امنیت وبسایت وردپرسی شما را افزایش دهد. از آنجا که سرور تنها توسط شما استفاده میشود، خطر حملات ناشی از سایر سایتهای میزبانی شده بر روی همان سرور مانند حملات Cross-Site کاهش مییابد.
میزبانی اختصاصی میتواند به طور قابل توجهی امنیت وبسایت وردپرسی شما را افزایش دهد. با داشتن کنترل کامل بر سرور و اعمال تنظیمات امنیتی سفارشی، میتوانید از وبسایت خود در برابر تهدیدات مختلف محافظت کنید. با ترکیب این مزایا با اقدامات امنیتی مناسب، میتوانید یک محیط امن و پایدار برای وبسایت وردپرسی خود فراهم کنید.
مزایای میزبانی اختصاصی برای امنیت وردپرس
کنترل کامل بر سرور:
با میزبانی اختصاصی، شما کنترل کامل بر تنظیمات و پیکربندیهای سرور خود دارید. این به شما اجازه میدهد تا تنظیمات امنیتی مورد نیاز خود را به صورت دقیق اعمال کنید.
منابع اختصاصی:
در میزبانی اختصاصی، تمامی منابع سرور (مانند CPU، RAM، و پهنای باند) به وبسایت شما اختصاص داده میشود. این امر به بهبود عملکرد و کاهش خطرات ناشی از اشتراک منابع با وبسایتهای دیگر کمک میکند.
بهبود امنیت شبکه:
با داشتن سرور اختصاصی، شما میتوانید از فایروالهای سفارشی، سیستمهای تشخیص و جلوگیری از نفوذ (IDS/IPS)، و دیگر ابزارهای امنیت شبکه برای محافظت از وبسایت خود استفاده کنید.
بهروزرسانیها و پچهای امنیتی:
شما میتوانید بهروزرسانیها و پچهای امنیتی سیستمعامل و نرمافزارهای سرور را به موقع و بدون تاخیر اعمال کنید، که این امر به کاهش خطرات امنیتی کمک میکند.
پیکربندیهای امنیتی سفارشی:
با کنترل کامل بر سرور، میتوانید پیکربندیهای امنیتی سفارشی مانند محدود کردن دسترسی به فایلها، تنظیمات خاص برای مجوزهای فایل و دایرکتوریها، و استفاده از ابزارهای رمزنگاری را اعمال کنید.
اقدامات امنیتی که میتوانید در میزبانی اختصاصی انجام دهید

استفاده از SSH و کلیدهای SSH:
برای اتصال به سرور خود از پروتکل SSH به جای FTP استفاده کنید و از کلیدهای SSH برای احراز هویت استفاده کنید.
نصب و پیکربندی فایروال:
از فایروالهای نرمافزاری مانند UFW یا CSF برای محدود کردن ترافیک ورودی و خروجی به سرور استفاده کنید.
تنظیمات امنیتی وبسرور:
تنظیمات امنیتی وبسرور خود را بهینهسازی کنید. برای مثال، تنظیمات Apache یا Nginx را به گونهای پیکربندی کنید که حملات XSS، CSRF، و SQL Injection را کاهش دهید.
استفاده از نرمافزارهای امنیتی:
نرمافزارهایی مانند Fail2Ban را نصب کنید که تلاشهای مشکوک برای ورود را شناسایی و مسدود میکنند.
پشتیبانگیری منظم:
پشتیبانگیری منظم از وبسایت و دادههای پایگاه داده خود انجام دهید و اطمینان حاصل کنید که این پشتیبانها در مکانی امن ذخیره میشوند.
10. استفاده از توابع فراردهی
برای نمایش ورودیهای کاربر از توابع فراردهی مانند esc_html, esc_attr, esc_url, و esc_textarea استفاده کنید.
11. استفاده از HTTP Headers
از HTTP Headers مانند Content Security Policy (CSP) برای محدود کردن منابع قابل اجرا در وبسایت استفاده کنید. CSP یک لایه امنیتی اضافی است که به شما امکان میدهد منابعی که در وبسایت شما قابل اجرا هستند را محدود کنید. این کار به جلوگیری از حملات XSS و تزریق کدهای مخرب کمک میکند.

default-src ‘self’ مشخص میکند که تمامی منابع باید از دامنه خود وبسایت بارگذاری شوند.
script-src ‘self’ https://trustedscripts.example.com مشخص میکند که فقط اسکریپتها از دامنه خود وبسایت و trustedscripts.example.com مجاز به بارگذاری هستند.
object-src ‘none’ بارگذاری هیچ گونه شیء (مانند Flash) را مجاز نمیداند.
style-src ‘self’ https://trustedstyles.example.com مشخص میکند که فقط استایلها از دامنه خود وبسایت و trustedstyles.example.com مجاز به بارگذاری هستند.
بهترین افزونهها برای مقابله با حمله به وردپرس
برای محافظت از وبسایتهای وردپرسی در برابر حملات DDOS، استفاده از افزونههای امنیتی میتواند یکی از راههای مؤثر باشد. در اینجا به چند افزونه وردپرسی معروف که میتوانند به مقابله با حملات DDOS کمک کنند، اشاره میکنم:
1. Wordfence Security
Wordfence یکی از محبوبترین افزونههای امنیتی وردپرس است که امکاناتی مانند فایروال وب اپلیکیشن، اسکن بدافزار، و محافظت در برابر حملات بروت فورس Brute Force را ارائه میدهد. این افزونه همچنین میتواند به شناسایی و جلوگیری از ترافیک مخرب کمک کند.
2. Sucuri Security
Sucuri یک افزونه امنیتی دیگر است که شامل محافظت در برابر حملات DDOS، اسکن بدافزار، و محافظت در برابر حملات بروت فورس میشود. Sucuri همچنین یک CDN ارائه میدهد که میتواند به کاهش بار ناشی از حملات DDOS کمک کند.
3. iThemes Security
iThemes Security قبلاً به نام Better WP Security شناخته میشد. امکانات مختلفی برای افزایش امنیت وبسایت وردپرسی ارائه میدهد، از جمله محافظت در برابر حملات بروت فورس و دیگر تکنیکهای نفوذ.
4. Cloudflare
اگرچه Cloudflare یک افزونه وردپرسی نیست، اما یک سرویس CDN و امنیتی است که به طور گسترده با وردپرس کار میکند. Cloudflare میتواند به کاهش حملات DDOS کمک کند و از طریق افزونه خود در وردپرس قابل مدیریت است. برای میزبانی های ایرانی و یا حتی میزبانی های خاراجی با ترافیک ایرانی همیشه یک گزینه مناسب نیست و باید با توجه به نوع کسب و کار و نوع ترافیک در استفاده از آن دقت کرد. چرا که ممکن است بعد از خرید پنل یا انتقال سایت بر روی سرور ابری کاهش چشم گیر ترافیک را شاهد باشیدو این مسئله ممکن است بین چند ساعت تا چند روز منجر به اختلال در عملکرد و فروش وبسایت شما شود.
5. Jetpack
Jetpack، که توسط Automattic توسعه یافته است، ویژگیهای امنیتی از جمله حفاظت در برابر حملات بروت فورس را ارائه میدهد. هرچند مستقیماً برای مقابله با DDOS طراحی نشده است، اما میتواند به عنوان بخشی از استراتژی امنیتی کلی مورد استفاده قرار گیرد.
6. All In One WP Security & Firewall
یک افزونه امنیتی جامع که با ارائه فایروال و تنظیمات امنیتی گسترده، به بهبود امنیت وبسایت کمک میکند.
7. Query Monitor
نمایش تمامی کوئریهای SQL اجرا شده در صفحه فعلی و نمایش اطلاعات دقیق در مورد هر کوئری. شناسایی کوئریهای کند و بهینهسازی آنها برای افزایش سرعت و کارایی سایت. نمایش اطلاعات کامل درباره کوئریها، شامل زمان اجرا، نام دیتابیس، و جزئیات خطاها. استفاده از دستورات Prepared Statements برای افزایش امنیت کوئریهای SQL و جلوگیری از حملات تزریق SQL.
مهاجمان از کجا به سیستم وردپرسی ما حمله میکنند
سیستم مدیریت محتوا وردپرس به دلیل محبوبیت و استفاده گستردهاش، هدف متداولی برای حملات سایبری از جمله حملات DDOS است. در اینجا به برخی از نقاط ضعف وردپرس در برابر این نوع حملات اشاره میکنیم:
1. پلاگینها و تمهای غیر امن
بسیاری از حملات DDOS به وبسایتهای وردپرسی از طریق پلاگینها و تمهایی که دارای آسیبپذیریهای امنیتی هستند، انجام میگیرد. استفاده از پلاگینها و تمهای نال شده یا غیرمعتبر این خطر را افزایش میدهد.
2. کانفیگ نامناسب
پیکربندی نادرست وردپرس میتواند به مهاجمان اجازه دهد تا به راحتی حملات DDOS را انجام دهند. به عنوان مثال، فعال نگه داشتن XML-RPC میتواند به مهاجمان اجازه دهد تا حملات بروت فورس یا DDOS را به صورت موثرتری انجام دهند.
3. مدیریت منابع ناکافی
وبسایتهای وردپرسی که بر روی هاستهای اشتراکی با منابع محدود اجرا میشوند، ممکن است در برابر حجم بالای ترافیک ناشی از حملات DDOS آسیبپذیر باشند.
4. نبود سیستمهای مقابله با حملات
وبسایتهایی که از سیستمهای تشخیص نفوذ IDS، سیستمهای جلوگیری از نفوذ IPS، و فایروالهای برنامه وب WAF استفاده نمیکنند، بیشتر در معرض خطر حملات DDOS قرار دارند.
5. عدم بهروزرسانی وردپرس
نگهداری نسخههای قدیمی وردپرس، پلاگینها، و تمها میتواند به مهاجمان اجازه دهد تا از آسیبپذیریهای شناخته شده برای انجام حملات DDOS استفاده کنند.
نکاتی برای افزایش امنیت برای حمله به وردپرس
ارزیابی نیازها: پیش از انتخاب یک راهکار امنیتی، نیازهای خاص وبسایت خود را ارزیابی کنید تا مطمئن شوید که راهکار انتخابی پاسخگوی این نیازها است.
تحقیق در مورد ویژگیها: بررسی کنید که آیا راهکار انتخابی ویژگیهای مورد نیاز مانند شناسایی خودکار حملات، فیلترینگ ترافیک و توانایی مدیریت حملات DDOS را دارد.
سازگاری با وردپرس: مطمئن شوید که راهکار امنیتی با وردپرس سازگار است و میتواند به راحتی با وبسایت شما ادغام شود.