امروز ۱۴ - اردیبهشت - ۰۳
دقیقه مطالعه

راهنمای اسلاگ فارسی در جنگو [persian slug for django]

راهنمای اسلاگ فارسی در جنگو [persian slug for django]
17 - مرداد - 1402

داشتن یک url واضح و کوتاه به موتورهای جستجو کمک می‌کند تا صفحات وب‌سایت بهتر و سریع‌تر ایندکس شوند و در سئوی وب‌سایت تاثیر مثبت دارد.

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

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

Slug فارسی در جنگو

بعد از اینکه پروژه جنگو خود را روی هاست های پارس‌وب‌سرور راه‌اندازی کردید (راهنمای راه‌اندازی پروژه جنگو روی هاست) نیاز به تغییراتی هست تا بتوانیم از url فارسی در جنگو استفاده کنیم.
برای مشاهده و تهیه هاست‌های پایتون می‌توانید به صفحه هاست پایتون پارس‌وب‌سرور مراجعه کنید و جزئیات پلن‌های مختلف را بررسی و پلن مورد نظر خود را انتخاب و خریداری کنید و پروژه جنگوی خود را راه‌اندازی کنید.

راهنمای قدم به قدم اضافه کردن اسلاگ فارسی به جنگو

اولین اقدام این هست که به فولدر اپ مورد نظر خود در فولدر پروژه برویم (blog در این پروژه) و در فایل models.py،  اسلاگ را تعریف کنیم:

from django.db import models
… class Post(models.Model):
title = models.CharField(max_length=200, unique=True,db_collation='utf8_persian_ci')
slug = models.SlugField(max_length=200, unique=True,allow_unicode=True,db_collation='utf8_persian_ci')

در مدلPOST خود، یک متغیر به نام slug تعریف می‌کنیم که نوع آن رو SlugField می‌دهیم (جزئیات بیشتر در مورد SlugField را می‌توانید در مستندات جنگو مشاهده کنید).
می‌توانیم در ادامه پارامتر تعداد حداکثر کاراکتر مجاز رو تعریف کنیم (max_length=200).

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

اسلاگ یونیک و منحصر به فرد

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

برای پشتیبانی اسلاگ جنگو در زبان فارسی، حتما باید پارامتر allow_unicode  برابر true قرار داده شود. (allow_unicode=True)

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

کولیشن فارسی در دیتابیس

با وارد کردن db_collation=utf8_persian_ci در زمان ساخت دیتابیس، پارامتر کولیشن ستون اسلاگ در جدول به utf8_persian_ci تغییر می‌کند و اسلاگ ها به درستی و با حروف فارسی در دیتابیس ذخیره خواهند شد.

اگر کولیشن روی مقدار دیگر که عموما به صورت پیش فرض بر روی latin1_swedish_ci باشد، حروف اسلاگ به صورت علامت سوال (؟) ذخیره می‌شود.

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

در قدم بعدی، در فایل urls.py  اپ مورد نظر خود، re_path را ایمپورت می‌کنیم.

from django.urls import include, path, re_path
from. import views

در انتهای همین فایل، در قسمت urlpatterns، برای اسلاگ‌های فارسی به جای path از re_path استفاده می‌کنیم


urlpatterns = [
…
re_path(r'(?P < slug > [^/]+)/?

و در پایان، در فایل views.py کدهای خود به این صورت ویرایش می‌کنیم:

from django.shortcuts import get_object_or_404, render
from django.utils.encoding import uri_to_iri
…
from.models import Post def post_detail(request, slug):
template_name = "post_detail.html"
post = get_object_or_404(Post, slug=uri_to_iri(slug))

post_detail.html نام فایل قالب ما هست که برای نمایش اطلاعات پست مورد استفاده قرار می‌گیرد.

برای اینکه در زمان وارد کردن عنوان پست، اسلاگ به صورت خودکار ساخته و در فیلد مربوط به آن وارد شود از کد زیر در فایل admin.py  استفاده می‌کنیم (در اینجا بیشتر توضیح داده شده است):

from django.contrib import admin
from.models import Comment, Post
…
class PostAdmin(admin.ModelAdmin):
list_display = ("title", "slug", "status", "created_on")
prepopulated_fields = {"slug": ("title",)}
…
admin.site.register(Post, PostAdmin)

بعد از انجام تغییرات در ترمینال، بعد از اینکه سورس اپلیکشن را در محیط ترمینال وارد کردیم
دستورات زیر را وارد می‌کنیم:

python manage.py makemigrations
python manage.py migrate

وارد کردن اسلاگ در بخش مدیریت جنگو

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

اسلاگ فارسی در جنگو

به طور مثال بعد از وارد کردن تایتل با متن “هاست‌های پارس‌وب‌سرور” لینک پست منتشر شده به صورت
https://djangokar.com/%D9%87%D8%A7%D8%B3%D8%AA-%D9%87%D8%A7%DB%8C-%D9%BE%D8%A7%D8%B1%D8%B3-%D9%88%D8%A8-%D8%B3%D8%B1%D9%88%D8%B1 ساخته می‌شود و با کلیک بر روی آن، صفحه مربوط به این پست باز خواهد شد.

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

ارور 404 بعد از فارسی کردن اسلاگ جنگو

ارور 404 در اسلاگ فارسی جنگو

این خطا 3 علت می‌تواند داشته باشد:

1- ریجکس re_path در فایل urls.py به اشتباه وارد شده باشد که باید اصلاح شود و مقدار صحیح وارد گردد

re_path(r'(?P<slug>[^/]+)/?$’, views.post_detail, name=”post_detail”),

2- ممکن است فانکشن re_path را در فایل urls.py اپ خود ایمپورت نکرده باشید (در مورد re_path بیشتر بدانید)

from django.urls import include, path, re_path

3- عدم استفاده از تابع uri_to_iri در فایل views.py اپ، که این مورد هم باعث خطای 404 در صفحات پست ما خواهد شد.

from django.utils.encoding import uri_to_iri

post = get_object_or_404(Post, slug=uri_to_iri(slug))

خطای TemplateDoesNotExist بعد از فارسی کردن اسلاگ جنگو

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

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

نام فایل تمپلت در خطا نمایش داده می‌شود و در صورتی که خود اپ دارای پوشه templates باشد این فایل باید در این فولدر ایجاد شود.

در غیر اینصورت باید در فولدر templates اپ اصلی (main app) پروژه جنگو ما آپلود شود تا این خطا رفع گردد.

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

, views.post_detail, name=”post_detail”), … ]

و در پایان، در فایل views.py کدهای خود به این صورت ویرایش می‌کنیم:


post_detail.html نام فایل قالب ما هست که برای نمایش اطلاعات پست مورد استفاده قرار می‌گیرد.

برای اینکه در زمان وارد کردن عنوان پست، اسلاگ به صورت خودکار ساخته و در فیلد مربوط به آن وارد شود از کد زیر در فایل admin.py  استفاده می‌کنیم (در اینجا بیشتر توضیح داده شده است):


بعد از انجام تغییرات در ترمینال بعد از اینکه سورس اپلیکشن را در محیط ترمینال وارد کردیم
دستورات زیر را وارد می‌کنیم:


وارد کردن اسلاگ در بخش مدیریت جنگو

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

اسلاگ فارسی در جنگو

به طور مثال بعد از وارد کردن تایتل با متن “هاست های پارس‌وب‌سرور” لینک پست منتشر شده به صورت
https://djangokar.com/%D9%87%D8%A7%D8%B3%D8%AA-%D9%87%D8%A7%DB%8C-%D9%BE%D8%A7%D8%B1%D8%B3-%D9%88%D8%A8-%D8%B3%D8%B1%D9%88%D8%B1 ساخته می‌شود و با کلیک بر روی آن، صفحه مربوط به این پست باز خواهد شد.

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

ارور 404 بعد از فارسی کردن اسلاگ جنگو

ارور 404 در اسلاگ فارسی جنگو

این خطا 3 علت می‌تواند داشته باشد:

1- ریجکس re_path در فایل urls.py به اشتباه وارد شده باشد که باید اصلاح شود و مقدار صحیح وارد گردد

re_path(r'(?P<slug>[^/]+)/?$’, views.post_detail, name=”post_detail”),

2- ممکن است فانکشن re_path را در فایل urls.py اپ خود ایمپورت نکرده باشید (در مورد re_path بیشتر بدانید)

from django.urls import include, path, re_path

3- عدم استفاده از تابع uri_to_iri در فایل views.py اپ، که این مورد هم باعث خطای 404 در صفحات پست ما خواهد شد.

from django.utils.encoding import uri_to_iri

post = get_object_or_404(Post, slug=uri_to_iri(slug))

خطای TemplateDoesNotExist بعد از فارسی کردن اسلاگ جنگو

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

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

نام فایل تمپلت در خطا نمایش داده می‌شود و در صورتی که خود اپ دارای پوشه templates باشد این فایل باید در این فولدر ایجاد شود.

در غیر اینصورت باید در فولدر templates اپ اصلی (main app) پروژه جنگو ما آپلود شود تا این خطا رفع گردد.

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

5/5 - (5 امتیاز)
دیدگاهتان را بنویسید

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

[bws_google_captcha]

دیدگاه های این نوشته

  • امید گفت:

    سلام
    لطفا پروژه که کار شده برای دانلود بزارید چک کنم

  • امیرحسین شمسی پور گفت:

    ”post_detail”
    این بخش به نظر میاد کوتیشن خوب گذاشته نشده و وقتی که کپی پیست خواستم کنم ارور داشت
    “post_detail”
    و مورد دیگه هم اینکه باکس مربوط به کدها براشون نیومده

    1. Admin گفت:

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