فوریه 14, 2025 By همیار 0

امنیت وبسایت جوملا ( از css تا cpanel ) راهنمای جامع و کامل گام به گام

ایجاد یک وب‌سایت امن در Joomla نیازمند انجام مجموعه‌ای از اقدامات امنیتی است تا از حملات احتمالی جلوگیری کرده و اطلاعات سایت جوملا در امان باشد. در این مقاله، مراحل و کدهای لازم برای بهبود امنیت سایت Joomla و امن سازی cpanel به تفصیل و مرحله به مرحله بیان می شود. دقت شود امنیت وبسایت یک مجموعه از اقدامات پیوسته و منظم است که بصورت دوره ای با توجه به تهدیدات جدید باید بازنگری ، سطح ریسک مشخص و اقدامات امنیتی بروزرسانی شود

۱. به‌روزرسانی جوملا و افزونه‌ها

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

گام اول:

  • به Joomla Admin Panel بروید.
  • به Extensions > Manage > Update بروید.
  • روی گزینه “Install the latest version” کلیک کنید.

کد برای اطمینان از به‌روزرسانی خودکار (در فایل configuration.php):

public $cachetime = '1'; // کاهش زمان کش برای سرعت بیشتر
public $debug = '0'; // خاموش کردن حالت دیباگ در محیط تولید

۲. تغییر پیش‌فرض نام کاربری “admin”

استفاده از نام کاربری پیش‌فرض “admin” می‌تواند امنیت سایت را به شدت کاهش دهد. برای جلوگیری از دسترسی غیرمجاز، نام کاربری مدیر را تغییر دهید و به آن پیچیدگی اضافه کنید مثلا zkms@5698.

گام دوم:

  • وارد Admin Panel شوید.
  • به Users > Manage بروید.
  • نام کاربری “admin” را تغییر دهید.

۳. استفاده از پسوردهای پیچیده

استفاده از پسوردهای ضعیف می‌تواند خطرات امنیتی زیادی ایجاد کند. همیشه از پسوردهای پیچیده برای حساب‌های خود استفاده کنید.

گام سوم:

  • برای هر حساب کاربری، یک پسورد با ترکیب حروف بزرگ و کوچک، اعداد و نمادها استفاده کنید.

کد مثال برای اضافه کردن سیاست پسورد پیچیده در Joomla (در فایل administrator/components/com_users/models/profile.php):

public function checkPassword($password) {
    if (strlen($password) < 12 || !preg_match('/[A-Z]/', $password) || !preg_match('/[0-9]/', $password)) {
        return false; // پسورد ضعیف
    }
    return true; // پسورد قوی
}

۴. استفاده از SSL برای رمزنگاری ارتباطات

فعال‌سازی SSL برای رمزنگاری ارتباطات، یک روش ضروری برای حفظ امنیت است. این کار به خصوص در مواقعی که کاربران اطلاعات حساس مانند پسوردها یا اطلاعات کارت اعتباری را وارد می‌کنند، اهمیت دارد.

گام چهارم:

  • در cPanel خود به بخش SSL/TLS بروید.
  • SSL Certificate را برای دامنه خود فعال کنید.
  • در Joomla، به Global Configuration بروید و گزینه Force SSL را فعال کنید.

کد برای فعال‌سازی SSL در Joomla (در فایل .htaccess):

RewriteEngine On
RewriteCond %{HTTPS} off
RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [L,R=301]

۵. پیکربندی دسترسی محدود به فایل‌ها و پوشه‌ها

جلوگیری از دسترسی به پوشه‌های خاص می‌تواند مانع از نفوذ هکرها به اطلاعات حساس شود. تنظیمات دقیق دسترسی‌ها در فایل‌های .htaccess و تغییر مجوزهای فایل‌ها و پوشه‌ها مهم است.

گام پنجم:

  • در cPanel به File Manager بروید.
  • پوشه‌های administrator, components, libraries, و media را از دسترسی عموم محدود کنید.

کد برای محدود کردن دسترسی به پوشه‌ها (در فایل .htaccess):

<FilesMatch "\.(htaccess|htpasswd)">
    Order Deny,Allow
    Deny from all
</FilesMatch>

۶. فعال‌سازی سیستم امنیتی و تشخیص نفوذ

فعال‌سازی سیستم‌های امنیتی مانند Firewall یا Intrusion Detection System (IDS) می‌تواند به شناسایی و جلوگیری از حملات کمک کند.

گام ششم:

  • از افزونه‌های امنیتی مانند Akeeba Admin Tools استفاده کنید که امکان اعمال قوانینی مانند فیلتر کردن IPهای مشکوک، محدود کردن تعداد تلاش‌های ورود ناموفق و مسدود کردن درخواست‌های مخرب را فراهم می‌کند.

کد تنظیمات امنیتی در افزونه Akeeba Admin Tools:

// جلوگیری از ورودهای مشکوک
public function blockSuspiciousIP($ip) {
    $blacklist = array('192.168.1.1', '123.45.67.89');
    if (in_array($ip, $blacklist)) {
        return false; // مسدود کردن
    }
    return true; // اجازه دسترسی
}

۷. پیکربندی دقیق cPanel برای امنیت بیشتر

برای تقویت امنیت سرور، می‌توان تنظیمات امنیتی مختلفی را در cPanel اعمال کرد.

گام هفتم:

  • وارد cPanel شوید.
  • به Security > SSH Access بروید و دسترسی SSH را محدود کنید.
  • در Security، گزینه Leech Protect را فعال کنید تا از دسترسی‌های غیرمجاز جلوگیری شود.
  • گزینه IP Blocker را برای مسدود کردن IPهای مشکوک فعال کنید.

۸. فعال‌سازی Log‌ها و بررسی‌های منظم

فعال کردن logهای امنیتی و بررسی منظم آن‌ها به شناسایی مشکلات و حملات احتمالی کمک می‌کند.

گام هشتم:

  • در Joomla, به System > Global Configuration بروید.
  • گزینه Log errors را فعال کنید تا گزارش‌های خطا ذخیره شود.

کد برای فعال‌سازی ثبت خطاها (در فایل configuration.php):

public $log_errors = '1'; // فعال‌سازی ثبت خطاها
public $error_reporting = 'maximum'; // نمایش حداکثر اطلاعات خطا

۹. نظارت و جلوگیری از حملات SQL Injection

حملات SQL Injection یکی از متداول‌ترین حملات در تسخیر امنیت وب‌سایت‌ها است. برای جلوگیری از این حملات، باید از sanitization و parameterized queries استفاده کنید.

گام نهم:

  • همیشه از prepared statements و parameterized queries برای ارتباط با دیتابیس استفاده کنید.

کد برای جلوگیری از SQL Injection (در کدهای PHP):

$stmt = $mysqli->prepare("SELECT * FROM users WHERE username = ?");
$stmt->bind_param("s", $username);
$stmt->execute();

۱۰. استفاده از افزونه‌های امنیتی

افزونه‌های امنیتی می‌توانند اقدامات امنیتی اضافی را به راحتی برای شما انجام دهند. افزونه‌هایی مانند Akeeba Backup, Admin Tools, JCH Optimize و RSFirewall می‌توانند به افزایش امنیت وبسایت کمک کنند.

با دنبال کردن این مراحل و کدهای امنیتی برای سایت Joomla خود، می‌توانید سطح امنیت سایت خود را به طور قابل توجهی افزایش دهید. حفظ امنیت به‌صورت مستمر و به‌روزرسانی منظم جوملا و افزونه‌ها از اهمیت بالایی برخوردار است. همچنین توجه به تنظیمات دقیق cPanel و اعمال قوانین امنیتی پیشرفته به شما کمک می‌کند تا سایت خود را در برابر تهدیدات مختلف محافظت کنید.

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

همیار امنیت