آموزش وب مستری

راهنمای گام به گام Robots.Txt

به این post امتیاز دهید

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

Robots.txt چیست

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

برخی باورهای غلط در مورد robots.txt

 از فهرست شدن محتوای سایت و نمایش داده شدن آن در میان نتایج جستجو جلوگیری می‌کند

اگر صفحه‌ای خاص را در فایل robots.txt لیست کرده باشید اما آدرس URL صفحه در منابع خارجی قرار داشته باشد، بازهم بات‌های موتورهای جستجو ممکن است در آن بخزند (Crawl) و این URL خارجی را فهرست کنند و در میان نتایج جستجو نشان دهند. همچنین، تمام ربات‌ها از دستورالعمل داده‌شده در فایل‌های robots.txt پیروی نمی‌کنند، بنابراین درهرحال ممکن است برخی بات‌ها بتوانند در صفحات درج‌شده در فایل robots.txt بخزند و آن‌ها را فهرست کنند. اگر می‌خواهید مانع دیگری هم برای جلوگیری از فهرست شدن قرار دهید می‌توانید از ربات Meta tag با مقدار ‘noindex’ در قسمت محتوا استفاده کنید. اگر آن را همانند شکل زیر برای صفحه‌های خاص استفاده کنید، همان نقش مانع را برایتان ایفا خواهد کرد:

<meta name=“robots” content=“noindex”>

از محتوای خصوصی محافظت می‌کند

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

عدم فهرست کرد دوباره محتوا را تضمین می‌کند

ازآنجاکه robots.txt فهرست نکردن یک صفحه را نمی‌تواند تضمین کند، نمی‌توان از آن برای جلوگیری از تکرار محتوا در سایت استفاده کرد. اما اگر از robots.txt برای جلوگیری از نشر دوباره محتوا استفاده می‌کنید، مطمئن شوید که دیگر روش‌های مطمئن مانند یک تگ rel=canonical را هم بکار گرفته باشید.


مقاله مرتبط: راهنمای جامع استفاده از ابزار بهینه‌ سازی وب‌ سایت هاست ایران


بلاک کردن تمام بات‌ها را تضمین می‌کند

برخلاف بات‌های گوگل، همه بات‌ها قانونی عمل نمی‌کنند و درنتیجه ممکن است از اصول فایل robots.txt برای جلوگیری از فهرست شدن یک فایل خاص پیروی نکنند. تنها راه block کردن این ربات‌های مخرب و ناخواسته این است که دسترسی آن‌ها به سرور وب خود را از طریق تنظیمات سرور یا به کمک یک فایروال شبکه block کنید، تازه با این فرض که آن بات از یک IP یکسان استفاده کند.

کاربردهای Robots.txt:

همان‌طور که در بخش قبل اشاره کردیم، استفاده از robots.txt در برخی موارد چندان مؤثر نیست. اما بااین‌حال، وجود این فایل بی‌دلیل نیست و دلیلش اهمیت آن برای SEO مربوط به صفحات است.

این‌ها مواردی از راه‌های کاربردی استفاده از robots.txt هستند:

  • ناامید کردن خزندگان از رجوع به فولدرهای شخصی
  • بات‌های خزنده را از مطالب کم‌اهمیت‌تر دور نگه داریم. این باعث می‌شود که زمان بیشتری را روی محتوای مهمی که می‌خواهیم در نتایج جستجو نشان داده شوند صرف کنند.
  • اینکه فقط به چند بات خاص اجازه خزیدن در صفحات سایت را بدهیم، به حفظ پهنای باند کمک می‌کند. بات‌های جستجو به‌طور پیش‌فرض به دنبال فایل‌های txt هستند. اگر آن‌ها پیدا نکنند یک خطای ۴۰۴ گزارش می‌کنند که می‌توانید آن را در میان فایل‌های گزارش پیدا کنید. برای جلوگیری از این کار باید حداقل از یک robots.txt پیش‌فرض مانند یک فایل robots.txt خالی استفاده کنید.
  • موقعیت نقشه سایت را به بات‌ها نشان دهید. برای این کار یک دستورالعمل در فایل txt خود وارد کنید که موقعیت نقشه سایت شمارا شامل شود:
Sitemap: http://yoursite.com/sitemap-location.xml

این دستور را می‌توانید در هر جای فایل robots.txt اضافه کنید چون این دستور از خط عامل کاربر (user-agent) مستقل است. تنها کاری که باید کنید این است که موقعیت نقشه سایت خود را در بخش sitemap-location.xml از URL مشخص کنید.اگر چندین نقشه سایت دارید، می‌توانید محل فایل Sitemap خود را نیز مشخص کنید.

نمونه‌هایی از فایل‌های Robots.txt:

دو بخش اصلی در یک فایل robots.txt وجود دارد: user-agent و Disallow

User-agent: عبارت user-agent معمولاً با یک wildcard (*) نمایش داده می‌شود که درواقع یک علامت ستاره است که نشان می‌دهد دستورهای Block برای تمام بات‌ها هستند. اگر می‌خواهید چند بات خاص Block شوند یا تنها به بعضی صفحات دسترسی داشته باشند، می‌توانید اسم بات را در پایین دستور user-agent درج کنید.

Disallow: وقتی در این بخش چیزی مشخص نشده باشد به این معنی است که بات‌ها می‌توانند در تمام صفحات سایت بخزند. به‌منظور بلاک کردن یک صفحه خاص باید تنها یک پیشوند URL را برای هر دستور disallow استفاده کنید. می‌توانید چند فولدر یا چند پیشوند URL را در بخش disallow فایل robots.txt درج کنید.

نمونه‌هایی از برخی استفاده‌های رایج از فایل‌های robots.txt به شرح زیر هستند:

برای اجازه دسترسی همه بات‌ها به تمام سایت (یعنی همان robots.txt پیش‌فرض) دستور زیر استفاده می‌شود:

User-agent:*
 Disallow:

برای بلاک کردن کل سرور در برابر بات‌ها:

User-agent:*
 Disallow: /

اجازه دسترسی به یک بات و عدم دسترسی بات‌های دیگر:

User-agent: Googlebot
 Disallow:

User-agent: *
 Disallow: /

بلاک کردن سایت برای یک بات:

User-agent: XYZbot
  Disallow: /

بلاک کردن برخی قسمت‌های سایت:

User-agent: *
 Disallow: /tmp/
 Disallow: /junk/

از این فایل robots.txt برای بلوک کردن تمام محتوای مربوط به یک نوع فایل خاص استفاده کنید. در این مثال، دسترسی به همه فایل‌های پاورپوینت Block شده است. (توجه کنید که علامت دلار $ به معنی انتهای خط دستور است):

User-agent: *
 Disallow: *.ppt$

بلوک کردن دسترسی بات‌ها به یک فایل خاص:

User-agent: *
 Disallow: /directory/file.html

برای اعمال اجازه خزیدن بات ها در برخی فایل‌های HTML در دایرکتوری که در برابر بات ها بلاک شده است، می‌توانید از یک دستور Allow استفاده کنید. برخی بات‌های خزنده قوی از دستور Allow در فایل robots.txt پشتیبانی می‌کنند. مثالی از این نمونه نشان داده‌شده است:

User-agent: *
 Disallow: /folder/
 Allow: /folder1/myfile.html

برای بلوک کردن URL هایی که شامل برخی عناصر جستجوی خاص هستند که ممکن است باعث نمایش دوباره محتوا شوند، از فایل robots.txt زیر استفاده می‌شود. در این مثال، هر URL که شامل یک علامت سؤال (؟) بوده بلوک شده است:

User-agent: *
 Disallow: /*?

گاهی حتی اگر یک صفحه را در فایل robots.txt درج کرده باشید، به دلایلی ازجمله لینک شدن از خارج ممکن است بازهم فهرست شود. برای آنکه این صفحه را کاملاً از نمایش داده شدن در میان نتایج جستجو بلاک کنید، می‌توانید متاتگ‌های noindex را به‌طور جداگانه در آن صفحات بگنجانید. همچنین می‌توانید با واردکردن کد زیر، یک تگ nofollow هم قرار دهید و به بات‌ها دستور دهید لینک‌های خارجی را دنبال نکنند. برای اینکه صفحه فهرست نشود باید از این استفاده کنید:

<meta name=“robots” content=“noindex”>

مقاله مرتبط: چگونه از ویژگی NoFollow استفاده کنیم؟


و برای اینکه صفحه مذکور فهرست نشود و لینک‌ها هم دنبال نشوند:

<meta name=“robots” content=“noindex,nofollow”>

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

نکته مهم دیگری که باید به آن توجه کنید این است که نباید هیچ URL بلاک شده در فایل robots.txt را در XML نقشه سایت خود قرار دهید. این اتفاق به‌ویژه اگر از چند ابزار برای سایت فایل robots.txt و XML نقشه سایت استفاده می‌کنید ممکن است رخ دهد. در چنین مواردی شاید مجبور شوید خودتان همه آن‌ها را به‌دقت بررسی کنید و ببینید آیا هیچ‌کدام از URL های Block شده در نقشه سایت هم هستند یا خیر. اگر سایت خود را در اکانت Google Webmaster Tools ثبت و تأیید کرده و نقشه سایتتان را هم در آن وارد کرده باشید، می‌توانید این مسئله را در اکانت خود بررسی کنید.

برای این کار به بخش Webmaster Tools > Optimization > Sitemaps بروید. اگر خطای crawl در نقشه سایت ثبت نشان می‌داد، می‌توانید روی آن دو بار کلیک کنید تا ببینید آیا مربوط به صفحه‌ای است که در robots.txt هم درج‌شده است یا خیر.

راه دیگر، استفاده از ابزار آزمایش فایل robots.txt در داخل GWT است. می‌توانید آن را در مسیر Webmaster Tools > Health > Blocked URLs پیدا کنید.

این ابزار یکی از روش‌های عالی در یادگیری نحوه استفاده از فایل robots.txt است. می‌توانید ببینید که بات‌های گوگل بعدازاینکه URL آزمایشی خود را وارد کردید چگونه با آن رفتار می‌کنند.


مقاله مرتبط: اهمیت متا تگ توضیحات Meta Description در سئو


در آخر نیز به برخی نکات مربوط به استفاده از robots.txt می‌پردازیم:

  • وقتی از یک اسلش (/) بعد از یک دستور یا فولدر استفاده می‌کنید، به این معنی است که txt هر دستور یا فولدر یا چیز دیگری که داخل آن باشد را بلاک می‌کند:
Disallow: /junk-directory/
  • دقت کنید که فایل‌های CSS و کدهای جاوا اسکریپت که محتوای غنی شمارا ارائه می‌کنند در فایل txt بلوک نشده باشند، در غیر این صورت مانع پیش‌نمایش خلاصه بخش‌ها می‌شوند.
  • دستور نگارش خود را با ابزار Google Webmaster Tool چک کنید تا اشتباهی نداشته باشد یا آن را به فردی که کاملاً به کار با txt آشناست واگذار کنید، در غیر این صورت ریسک بلوک شدن محتوای مهم سایت را به جان می‌خرید.
  • اگر دو بخش user-agent دارید، که یکی برای همه بات‌ها و یکی برای یک بات خاص مثلاً بات‌های گوگل است، باید در نظر داشته باشید که خزنده‌های بات‌های گوگل تنها دستورهای داخل بخش user-agent مربوط به بات‌های گوگل را دنبال خواهند کرد و به دستورهای بخش کلی که با وایلدکارت (*) مشخص‌شده است عمل نمی‌کنند. در این حالت، شاید مجبور شوید دستورهای disallow که در بخش user-agent کلی آورده‌اید را در بخش بات‌های گوگل هم دوباره بنویسید. به مثال زیر توجه کنید:
User-agent: *
Disallow: /folder1/
Disallow: /folder2/
Disallow: /folder3/


User-agent: googlebot
 Crawl-delay: 2
Disallow: /folder1/
Disallow: /folder2/
Disallow: /folder3/
Disallow: /folder4/
Disallow: /folder5/
خرید هاست لینوکس

تیم تحریریه هاست ایران

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

Related Articles

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

21  +    =  24

Back to top button