为什么我在生成的slugs网址中总是有额外的%2F
?
当我在终端打印出来时,所有的slu are都在下面正确生成,但我不知道为什么网址会有额外的%2F
某处出了点问题,但我似乎无法发现它
在我看来,我正在使用<a href = "{{ group.get_absolute_url }}">...
来获取slu ..现在,这可以工作,但输出上述问题。如果我href = "{% url 'group' group.slug %}
这会引发一个错误,它无法找到反向匹配。
示例:群组标题为a group
,网址为../%2Fgroup/a-group/
(r'^/group/(?P<slug>[-\w\d]+)/$', "group"),
模型
class BlogGroup(models.Model):
title = BleachField()
image = models.ImageField(upload_to="uploads/group_images", default="uploads/group_images/none/none.jpg")
created = models.DateTimeField(default = datetime.now)
slug = models.SlugField(unique = True)
def __str__(self):
return self.title
def get_absolute_url(self):
return reverse("blog.views.group", kwargs = {'slug':self.slug})
形式
class BlogGroupForm(forms.ModelForm):
def __init__(self, *args, **kwargs):
super(BlogGroupForm, self).__init__(*args, **kwargs)
self.fields["title"].requried = True
self.fields["image"].required = True
self.fields["title"].widget = forms.TextInput()
class Meta:
model = BlogGroup
fields = ["title", "image", "slug"]
def save(self, commit = False):
instance = super(BlogGroupForm, self).save(commit = False)
return truncate_slug(instance, BlogGroup)
utils.py
from django.utils.text import slugify
import itertools
def truncate_slug(instance, arg):
length = arg._meta.get_field('slug').max_length
instance.slug = original_slug = slugify(instance.title)[:length]
for x in itertools.count(1):
if not arg.objects.filter(slug = instance.slug).exists():
break
instance.slug = "%s-%d" % (original_slug[:length - len(str(x)) -1], x)
instance.save()
return instance
答案 0 :(得分:5)
你的正则表达式开头有正斜杠。如果您将其删除,则会阻止%2f
(请注意%2f
是一个带编号的正斜杠)。
url(r'^group/(?P<slug>[-\w]+)/$', "group", name="group"),
请注意,我也
\d
,因为\w
已包含数字0-9 url()
(Django 1.8+的最佳实践)并命名为url模式。这应该有希望通过{% url %}
标记工作来反转网址。在您的模板中使用group.get_absolute_url
很好,但如果您不想使用,则无需使用网址标记。