حالت دیباگ وردپرس و فایل debug.log

حالت دیباگ وردپرس و فایل debug.log
Common File Edit Streamline Icon: https://streamlinehq.com
علی جلادتی
Common File Text Clock Streamline Icon: https://streamlinehq.com
اکتبر 12, 2025
Attachment Streamline Icon: https://streamlinehq.com
Programming Hold Code 2 Streamline Icon: https://streamlinehq.com
html , css , java

فهرست مطالب

چرا دیباگینگ وردپرس یک مهارت ضروری است؟

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

حالت دیباگ وردپرس: تابو را بشکنید و خطاها را ببینید

به طور پیش‌فرض، وردپرس سعی می‌کند یک تجربه کاربری تمیز و بدون پیغام‌های ترسناک فنی ارائه دهد. وقتی یک خطای PHP رخ می‌دهد، ممکن است فقط یک “صفحه سفید مرگ” (White Screen of Death) ببینید یا یک پیغام کلی مانند “مشکلی پیش آمده است”. این رفتار اگرچه کاربرپسند است، اما برای توسعه‌دهندگان و مدیران سایت کاملاً بی‌فایده است. حالت دیباگ این تابو را می‌شکند و تمام خطاها، اخطارها و notices را به طور کامل روی صفحه نمایش می‌دهد. البته توجه داشته باشید که دلیل اصلی مخفی کردن این خطاها،افزایش امنیت سایت شما است.

چگونه حالت دیباگ را فعال کنیم؟

فعال‌سازی این قابلیت بسیار ساده است و تنها نیاز به ویرایش یک فایل دارد: wp-config.php. این فایل، هسته مرکزی تنظیمات وردپرس شماست. مراحل این ویرایش:

دسترسی به فایل wp-config.php: از طریق یک کلاینت FTP (مانند FileZilla) یا ابزارهای دیگری مانند cPanel، به پوشه اصلی وردپرس مراجعه کنید (همان جایی که پوشه‌های wp-content, wp-admin, و wp-includes قرار دارند). فایل wp-config.php را پیدا کنید.

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

ویرایش: فایل را در یک ادیتور باز کنید. در فایل، به دنبال خطی بگردید که می‌گوید:
/* That’s all, stop editing! Happy publishing. */

درج کد دیباگ: دقیقاً قبل از این خط، کدهای زیر را اضافه کنید. اینجا سه سناریو داریم:

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

				
					define( 'WP_DEBUG', true );
define( 'WP_DEBUG_DISPLAY', true );
define( 'WP_DEBUG_LOG', false );
				
			

سناریو دوم: ایمن برای سایت زنده (لاگ کردن بدون نمایش)
این روش، مطمئن‌ترین و حرفه‌ای‌ترین روش است. خطاها به کاربران نمایش داده نمی‌شوند (از تجربه کاربری بد جلوگیری می‌شود) اما همگی در یک فایل متنی ذخیره می‌شوند تا شما بعداً بتوانید آن‌ها را بررسی کنید.

				
					define( 'WP_DEBUG', true );
define( 'WP_DEBUG_DISPLAY', false );
define( 'WP_DEBUG_LOG', true );
				
			

سناریو سوم: شکارچی حرفه‌ای خطاها (نمایش و لاگ همزمان)
این روش برای زمانی است که می‌خواهید همزمان خطاها را روی صفحه ببینید و یک گزارش مکتوب نیز داشته باشید.

				
					define( 'WP_DEBUG', true );
define( 'WP_DEBUG_DISPLAY', true );
define( 'WP_DEBUG_LOG', true );
				
			

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

معرفی قهرمان گمنام: فایل error_log وردپرس

وقتی WP_DEBUG_LOG را روی true تنظیم می‌کنید، وردپرس یک فایل به نام debug.log در پوشه /wp-content/ ایجاد می‌کند. این فایل، دفترچه خاطرات تمام مشکلات سایت شماست.

نکته تمایز: این فایل را با فایل error_log عمومی سرور اشتباه نگیرید. فایل debug.log مخصوص خود وردپرس است، در حالی که فایل error_log (که معمولاً در پوشه ریشه دامنه یا پوشه‌های مختلف وجود دارد) مربوط به خطاهای سرور (مانند خطاهای Apache یا PHP خارج از وردپرس) است.

چگونه فایل debug.log را پیدا و تحلیل کنیم؟

به پوشه /wp-content/ بروید. فایل debug.log را در آنجا خواهید یافت. این یک فایل متنی ساده است. آن را با هر ویرایشگر متنی می‌توانید باز کنید. هر خطا در یک خط جداگانه و با timestamp (زمان وقوع) ثبت می‌شود.

تفسیر زبان خطاها (دیکشنری دیباگ):

Notice (اطلاع): یک پیغام اطلاعاتی است که معمولاً خطری ندارد اما نشان می‌دهد کد می‌تواند بهینه‌تر نوشته شود.

Warning (اخطار): یک مشکل غیرحاد که اجرای اسکریپت را متوقف نمی‌کند، اما باید جدی گرفته شود (مثلاً پارامترهای نادرست برای یک تابع).

Error (خطا): یک مشکل جدی که اجرای اسکریپت را متوقف می‌کند (مانند فراخوانی یک تابع یا کلاس که وجود ندارد). این همان چیزی است که معمولاً منجر به “صفحه سفید” می‌شود.

Fatal Error (خطای مهلک): بدترین نوع خطا که بلافاصله اجرای اسکریپت را خاتمه می‌دهد.

یک استراتژی عملی برای عیب‌یابی با استفاده از این ابزارها

فرض کنید با یک “صفحه سفید” مواجه شده‌اید. مراحل زیر را دنبال کنید:

  1. حالت دیباگ را به شکل لاگ‌کننده (سناریو دوم) فعال کنید.
  2. صفحه مشکل‌دار را در مرورگر خود رفرش (Refresh) کنید.
  3. به پوشه /wp-content/ رفته و فایل debug.log را بررسی کنید.
  4. آخرین خطاهای ثبت‌شده، به خصوص خطاهای از نوع Error یا Fatal Error را پیدا کنید.
  5. پیغام خطا را کپی کرده و در گوگل جستجو کنید. تقریباً 99% مشکلات وردپرسی که با آن‌ها روبرو می‌شوید، توسط دیگران نیز تجربه شده و راه‌حل آن وجود دارد.

نکات پایانی و امنیتی بسیار مهم

هرگز حالت دیباگ نمایشی (WP_DEBUG_DISPLAY => true) را روی یک سایت عمومی و زنده فعال نکنید. این کار اطلاعات حساس مسیرهای فایل و ساختار داخلی سایت شما را در معرض دید همه قرار می‌دهد و یک ریسک امنیتی بزرگ است.

پس از اتمام فرآیند عیب‌یابی، حتماً حالت دیباگ را غیرفعال کنید. کافی است مقدار WP_DEBUG را به false تغییر دهید.

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

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

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

برای پرسش سوال یا لایک/دیس‌لایک باید وارد حساب کاربری خود شوید.