FAILED TO OPEN STREAM

رفع خطای failed to open stream در وردپرس

خطای failed to open stream در وردپرس، معمولا بیانگر وجود مشکلی در دسترسی به یک فایل یا مسیر آن فایل است.

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

در این مقاله، تیم دولوپ به بررسی دقیق این ارور از منظر فنی پرداخته و راه حل هایی برای توسعه دهندگان و مدیران سایت ارائه خواهد داد.

خطای Failed to Open Stream در ورد پرس چیست
خطای Failed to Open Stream در ورد پرس چیست

خطای Failed to Open Stream در وردپرس چیست؟

خطای Failed to Open Stream زمانی رخ می‌دهد که وردپرس قادر به یافتن یا دسترسی به یک فایل یا منبع خاص (مانند فایل‌های قالب، افزونه یا منابع دیگر) نیست. این مشکل مشابه برخی خطاهای دیگر وردپرس مانند حل خطای too many redirects نیازمند بررسی مسیر فایل‌ها، تنظیمات درست و رفع تداخل بین افزونه‌ها و قالب‌ها است تا عملکرد سایت به حالت عادی بازگردد.

این خطا اغلب با پیغامی همراه است که جزئیاتی مانند مسیر فایل یا نوع خطا (مانند “No such file or directory” یا “Permission denied”) را نشان می‌دهد.

دلایل اصلی این خطا هم شامل موارد زیر است:

  • مشکلات مجوز فایل (File Permissions)
  • مسیر نادرست فایل
  • مشکلات افزونه یا قالب
  • خطاهای سرور

مشکلات مجوز فایل (File Permissions)

یکی از شایع ترین دلایلی که باعث بروز خطای failed to open stream در وردپرس می‌شود، تنظیم نادرست مجوزهای دسترسی به فایل ها و پوشه هاست.

در سیستم‌های مبتنی بر لینوکس، هر فایل یا پوشه دارای سطح خاصی از دسترسی برای کاربران مختلف (مالک، گروه و سایر کاربران) است. پس اگر سطح دسترسی فایل‌ها به گونه‌ای تنظیم شده باشد که وردپرس نتواند به آن‌ها دسترسی داشته باشد، هنگام تلاش برای خواندن یا نوشتن فایل، این خطا ظاهر خواهد شد. در چنین شرایطی، رفع ارور permission denied با اصلاح مجوزهای دسترسی فایل‌ها یا پوشه‌ها و اطمینان از صحیح بودن مالکیت آن‌ها می‌تواند مشکل را برطرف کند و اجازه دهد سایت بدون خطا اجرا شود.

یعنی مثلا اگر مجوز پوشه ای که افزونه ها یا قالب ها در آن قرار دارند روی حالت “read-only” برای کاربر وب سرور باشد، وردپرس نمی‌تواند فایل ها را لود کند.

برای رفع این مشکل، شما باید مجوز فایل ها را روی 644 و پوشه‌ها را روی 755 تنظیم کنید.

البته حواستان باشد که این عملیات باید با دقت انجام شود تا از بروز آسیب های امنیتی به ساختار و مسیر فایل ها جلوگیری شود.

استفاده از FTP یا پنل مدیریت هاست مانند CPanel هم می‌تواند برای بررسی و تنظیم مجوزها بسیار مفید باشد.

مسیر نادرست فایل

خطای failed to open stream ممکن است به دلیل وارد کردن مسیر نادرست به فایل مورد نظر در کدهای PHP یا تنظیمات وردپرس هم رخ بدهد.

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

این مشکل زمانی اتفاق می‌افتد که فایلی به اشتباه حذف شده، نام آن تغییر کرده یا در حین انتقال سایت، مسیر فایل ها به درستی بروزرسانی نشده است.

برای رفع این مشکل، باید مطمئن شوید که مسیرها به صورت دقیق و کامل نوشته شدند.

استفاده از توابع وردپرسی ای مثل get_template_directory() یا plugin_dir_path() به جای وارد کردن مسیرها به صورت دستی، می‌تواند از بروز چنین خطاهایی جلوگیری کند. 

مشکلات افزونه یا قالب

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

علاوه بر این، مشکلاتی مانند تنظیمات نادرست مسیر فایل‌ها، محدودیت‌های سرور، یا خطاهای مجوز دسترسی (Permissions) نیز می‌توانند باعث بروز چنین مشکلاتی شوند. وقتی این خطاها رخ می‌دهند، ممکن است بخش‌هایی از سایت به درستی نمایش داده نشوند، امکانات افزونه‌ها غیر فعال شوند، یا حتی سایت با ارورهای جدی مواجه شود که تجربه کاربران را مختل کند. برای حل این مشکل، بررسی کامل مسیر فایل‌ها، اطمینان از سازگاری نسخه‌ها و بازنشانی یا جایگزینی فایل‌های آسیب‌دیده ضروری است.

به عنوان مثال، ممکن است یک قالب سفارشی به فایل CSS یا JS خاصی ارجاع دهد که در مسیر موردنظر وجود ندارد و همین مشکل باعث بروز خطای failed to open stream شود.

همچنین افزونه هایی که از توابع خاصی برای بارگذاری فایل‌ها استفاده می‌کنند، در صورت ناقص بودن نصب یا خرابی فایل‌ها، مستعد این نوع خطا هستند.

برای رفع این مشکل، ابتدا باید افزونه یا قالب موردنظر را غیرفعال کرده و عملکرد سایت را بررسی کنید.

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

البته بررسی لاگ های خطای وردپرس یا فایل debug.log هم می‌تواند اطلاعات دقیقی از منبع ارور در اختیار شما قرار دهد.

خطاهای سرور

خطای failed to open stream گاهی اوقات ریشه در مشکلات پیکربندی سرور یا محدودیت های اعمال شده در تنظیمات PHP دارد.

محدودیت‌هایی مثل open_basedir یا غیرفعال بودن برخی توابع PHP می‌توانند مانع از دسترسی وردپرس به فایل‌ها یا مسیرهای خاص شوند. بعضیوقت ها هم در صورتی که سرور به درستی فایل های مورد نظر را بارگذاری نکند یا تنظیمات مربوط به مسیرهای پیش‌فرض در فایل های پیکربندی مانند php.ini یا .htaccess اشتباه باشد، این خطا به وجود می‌آید.

در هاست های اشتراکی سطح دسترسی به تنظیمات سرور محدود است. اما در سرورهای اختصاصی یا VPS می‌توان این موارد را مستقیما بررسی و اصلاح کرد.

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

رفع خطای Failed to Open Stream در وردپرس
رفع خطای Failed to Open Stream در وردپرس

روش های رفع خطای Failed to Open Stream در وردپرس

برای رفع خطای failed to open stream در سایت های وردپرسی، می‌توانید از روش های زیر استفاده کنید:

1. بررسی مجوزهای فایل و پوشه:

  • مجوزهای فایل ها در وردپرس معمولا باید روی 644 و پوشه‌ها روی 755 تنظیم شوند.
  • از طریق File Manager در کنترل پنل هاست یا با استفاده از FTP (مانند FileZilla) می‌توانید مجوزها را بررسی و اصلاح کنید.
  • برای تغییر مجوزها، روی فایل یا پوشه راست‌کلیک کرده و گزینه “Change Permissions” را انتخاب کنید.

2. بررسی مسیر فایل‌ها:

  • خطای “No such file or directory” نشان دهنده ی مسیر نادرست است. بررسی کنید که فایل یا پوشه موردنظر در سرور وجود دارد.
  • اگر فایل وجود ندارد، ممکن است نیاز باشد افزونه یا قالب را دوباره نصب کنید.

3. غیرفعال کردن افزونه‌ها و قالب‌ها:

  • گاهی اوقات افزونه‌ها یا قالب‌های معیوب باعث این خطا می‌شوند. برای بررسی، تمام افزونه‌ها را غیرفعال کنید:
  • به پوشه assets/plugins بروید و نام پوشه افزونه‌ها را تغییر دهید (مثلا به plugins_old).
  • اگر خطا برطرف شد، افزونه ها را یکی یکی فعال کنید تا افزونه مشکل ساز شناسایی شود.
  • برای قالب، به‌طور موقت به یک قالب پیش‌فرض وردپرس (مانند Twenty Twenty-Five) سوئیچ کنید.
روش های رفع خطای Failed to Open Stream در وردپرس
روش های رفع خطای Failed to Open Stream در وردپرس

4. افزایش محدودیت‌های PHP:

  • خطاهایی مانند “Permission denied” ممکن است به دلیل محدودیت‌های PHP باشد. فایل php.ini یا .htaccess را بررسی کنید و محدودیت‌های حافظه (memory_limit) یا زمان اجرا (max_execution_time) را افزایش دهید.
  • به عنوان مثال، در فایل php.ini می‌توانید خط زیر را اضافه کنید:

memory_limit = 256M

5. بررسی لاگ‌های خطا:

  • لاگ‌های خطای سرور یا فایل debug.log وردپرس (در پوشه assets) می‌توانند جزئیات بیشتری درباره خطا ارائه دهند.
  • برای فعال کردن حالت دیباگ، در فایل wp-config.php خطوط زیر را اضافه کنید:

define('WP_DEBUG', true);

define('WP_DEBUG_LOG', true);

define('WP_DEBUG_DISPLAY', false);

علت بروز خطاتوضیح مشکلروش‌های رفع خطاسطح دشواری
مسیر فایل اشتباه استوقتی مسیر فایل یا پوشه‌ای که در کد ذکر شده اشتباه باشد، وردپرس نمی‌تواند آن را پیدا کند.مسیر فایل را در کد (مثلا در require_once یا include) بررسی کنید و از مسیر نسبی یا مطلق درست استفاده کنید.آسان
دسترسی فایل‌ها محدود است (File Permission)گاهی دسترسی فایل یا پوشه به درستی تنظیم نشده و PHP اجازه خواندن یا نوشتن ندارد.سطح دسترسی را روی 644 برای فایل‌ها و 755 برای پوشه‌ها تنظیم کنید.متوسط
فایل یا افزونه حذف یا خراب شده استممکن است فایلی که باید بارگذاری شود وجود نداشته یا به اشتباه پاک شده باشد.فایل را دوباره آپلود یا افزونه را مجددا نصب کنید.آسان
آدرس URL اشتباه در فراخوانی منابعدر قالب یا افزونه از آدرس نادرست برای فایل‌های CSS یا JS استفاده شده است.لینک‌ها را در functions.php یا تنظیمات قالب بررسی و اصلاح کنید.آسان
محدودیت تنظیمات PHP (مثل open_basedir)تنظیمات امنیتی هاست ممکن است مانع دسترسی PHP به مسیر خاصی شود.از هاست بخواهید محدودیت open_basedir را بررسی و در صورت نیاز اصلاح کند.سخت
نسخه PHP ناسازگار با افزونه یا قالببرخی افزونه‌ها با نسخه خاصی از PHP سازگار نیستند.نسخه PHP را در کنترل‌پنل هاست ارتقا دهید (مثلاً از 7.4 به 8.1).متوسط
مشکل در فایل .htaccessگاهی قوانین اشتباه در .htaccess مانع بارگذاری فایل‌ها می‌شود.فایل .htaccess را بازنشانی کنید یا از بخش تنظیمات → پیوندهای یکتا آن را دوباره تولید کنید.متوسط

نکات مهمی که باید درباره ی خطای Failed to Open Stream در وردپرس بدانید

  • همیشه قبل از انجام تغییرات در فایل‌ها یا تنظیمات وردپرس، از سایت خود نسخه پشتیبان تهیه کنید.
  • وردپرس، قالب‌ها و افزونه‌ها را به‌روز نگه دارید تا از مشکلات ناشی از نسخه‌های قدیمی جلوگیری شود.
  • استفاده از هاست با کیفیت و پشتیبانی قوی می‌تواند از بروز خطاهای سرور جلوگیری کند.
  • گاهی اوقات این خطا ممکن است به دلیل مشکلات امنیتی یا هک شدن سایت باشد. از افزونه‌های امنیتی مانند Wordfence استفاده کنید.
  • اگر مشکل از سرور باشد، تیم پشتیبانی هاستینگ می‌تواند به شما کمک کند.

رفع خطای Failed to Open Stream در وردپرس با دولوپ

اگر با خطای Failed to Open Stream در وردپرس مواجه شدید و نمی‌خواهید وقت ارزشمندتان را صرف آزمون و خطای راه حل های پیچیده کنید، می‌توانید حل این مشکل و مشاوره وردپرس را به یک تیم حرفه‌ای توسعه و پشتیبانی سایت مثل تیم دولوپ بسپارید.

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

فرقی هم نمی‌کند که مشکل از ناهماهنگی آدرس سایتتان باشد یا اختلال در افزونه‌ها یا حتی تنظیمات سمت سرور!

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

نتیجه گیری از رفع خطای failed to open stream 

خطای Failed to Open Stream در وردپرس می‌تواند به دلایل مختلفی رخ دهد، از جمله مشکلات مربوط به مجوز فایل‌ها (File Permissions)، مسیرهای نادرست فایل‌ها، افزونه‌ها یا قالب‌های معیوب، و حتی بروزرسانی ناقص سیستم وردپرس. این خطا معمولا باعث می‌شود بخش‌هایی از سایت به درستی بارگذاری نشوند و امکانات افزونه‌ها یا قالب‌ها مختل شود، که تجربه کاربران را تحت تأثیر قرار می‌دهد.

با بررسی دقیق مسیر فایل‌ها، اصلاح مجوزهای دسترسی، غیرفعال کردن افزونه‌ها یا قالب‌های ناسازگار و جایگزینی فایل‌های آسیب‌دیده، می‌توانید این خطا را به راحتی برطرف کنید. همچنین بررسی فایل wp-config.php و مسیرهای فراخوانی فایل‌ها می‌تواند در شناسایی سریع‌تر مشکل کمک کند.

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

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

سوالات مربوط به خطای Failed to Open Stream

1. خطای Failed to Open Stream در وردپرس به چه معناست؟

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

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

4.8/5 از (17 امتیاز)