python - 当前路径 {% url 'post_new' %) 与其中任何一个都不匹配
问题描述
我正在尝试让一个应用程序在 django 中运行,但我遇到了这个错误:当前路径与其中任何一个都不匹配,即使我无法确定代码的哪一部分有问题。这是我的代码:views.py: from django.shortcuts import render from django.http [![enter image description here][1]][1]
[1]: https://i.stack.imgur.com/QKhGg.png
----------------------------------------------------------------------------------------
views.py
from django.shortcuts import render,get_object_or_404,redirect
from django.utils import timezone
from django.contrib.auth.decorators import login_required #function based
from django.contrib.auth.mixins import LoginRequiredMixin #Class based
from blog.models import Post,Comment
from blog.forms import PostForm,CommentForm
from django.urls import reverse_lazy
from django.views.generic import (TemplateView,ListView,DetailView,
CreateView,UpdateView,DeleteView)
# Create your views here.
class AboutView(TemplateView):
template_name = 'about.html'
class PostListView(ListView):
model = Post
def get_queryset(self):
return Post.objects.filter(published_date__lte=timezone.now()).order_by('-published_date')
# "__lte" means less than or equal to and "-" means order_by descending order
class PostDetailView(DetailView):
model = Post
class CreatePostView(LoginRequiredMixin,CreateView):
login_url = '/login/'
redirect_field_name = 'blog/post_detail.html'
form_class = PostForm
model = Post
class UpdatePostView(LoginRequiredMixin,UpdateView):
login_url = '/login/'
redirect_field_name = 'blog/post_detail.html'
form_class = PostForm
model = Post
class DeletePostView(LoginRequiredMixin,DeleteView):
login_url = '/login/'
success_url = reverse_lazy('post_list')
class DraftListView(LoginRequiredMixin,ListView):
login_url = '/login/'
redirect_field_name = 'blog/post_list.html'
model = Post
def get_queryset(self):
return Post.objects.filter(published_date__isnull=True).order_by('created_date')
@login_required
def post_publish(request,pk):
post = get_object_or_404(Post, pk=pk)
post.publish
return redirect('post_detail', pk=pk)
@login_required
def add_comment_to_post(request,pk):
post = get_object_or_404(Post, pk=pk)
if request.method == 'POST':
form = CommentForm(request.POST)
if form.is_valid():
comment = form.save(commit=False)
comment.post = post
comment.save()
return redirect('post_detail', pk=post.pk)
else:
form = CommentForm()
return render(request, 'blog/comment_form.html', {'form':form})
@login_required
def comment_approve(request,pk):
comment = get_object_or_404(Comment, pk=pk)
comment.approve()
return redirect('post_detail', pk=comment.post.pk)
@login_required
def comment_remove(request,pk):
comment = get_object_or_404(Comment, pk=pk)
post_pk = comment.post.pk
comment.delete()
return redirect('post_detail', pk=post_pk)
----------------------------------------------------------------------------------------
model.py
from django.db import models
from django.utils import timezone
from django.urls import reverse
# Create your models here.
class Post(models.Model):
author = models.ForeignKey('auth.User',on_delete=models.CASCADE)
title = models.CharField(max_length=200)
text = models.TextField()
created_date = models.DateTimeField(default=timezone.now())
published_date = models.DateTimeField(blank=True,null=True)
def publish(self):
self.published_date = timezone.now()
self.save()
def approve_comments(self):
return self.comments.filter(approved_comments=True)
def get_absolute_url(self):
return reverse("post_detail",kwargs={'pk':self.pk})
def __str__(self):
return self.title
class Comment(models.Model):
author = models.ForeignKey('blog.post',related_name='comments',on_delete=models.CASCADE)
title = models.CharField(max_length=200)
text = models.TextField()
created_date = models.DateTimeField(default=timezone.now())
approved_comment = models.BooleanField(default=False)
def approve(self):
self.approved_comment = True
self.save()
def get_absolute_url(self):
return reverse("post_list")
def __str__(self):
return self.text
----------------------------------------------------------------------------------------
urls.py
from django.contrib import admin
from django.urls import path,include
from django.contrib.auth import views
urlpatterns = [
path('admin/', admin.site.urls),
path('',include('blog.urls')),
path('accounts/login/',views.LoginView.as_view(),name = 'login'),
path('accounts/logout/', views.LogoutView.as_view(), name = 'logout',kwargs={'next_page':'/'}),
]
----------------------------------------------------------------------------------------
urls.py myapp
from django.urls import path
from blog import views
urlpatterns = [
path('', views.PostListView.as_view(), name = 'post_list'),
path('post/<int:pk>', views.PostDetailView.as_view(), name = 'post_detail'),
path('post/new/', views.CreatePostView.as_view(), name = 'post_new'),
path('post/<int:pk>/edit/', views.UpdatePostView.as_view(), name = 'post_edit'),
path('post/<int:pk>/remove/', views.DeletePostView.as_view(), name = 'post_remove'),
path('draft/', views.DraftListView.as_view(), name = 'post_draft_list'),
path('post/<int:pk>/comment', views.add_comment_to_post, name = 'add_comment_to_post'),
path('comment/<int:pk>/approve', views.comment_approve, name = 'comment_approve'),
path('comment/<int:pk>/remove', views.comment_remove, name = 'comment_remove'),
path('post/<int:pk>/publish', views.post_publish, name = 'post_publish'),
path('about/', views.AboutView.as_view(), name = 'about'),
]
解决方案
推荐阅读
- django-admin - 有没有办法将组的所有成员设置为 django 中的超级用户?
- intellij-idea - IntelliJ 中的条形消失了
- php - 如示例所示,如何在数组中显示 MySQL 数据?
- java - 哈希表:赎金票据hackerrank
- java - 服务器没有收到来自客户端的请求
- angular - 对具有路由器依赖性的 Angular 服务进行单元测试:“TypeError:无法读取未定义的属性 'navigate'”
- python - 如何在数组索引中排序到索引
- linux - ARToolkit 和 Linux 目标
- database-design - 微服务 - 不同表上的目录和库存跟踪
- c++ - 如何修复“对类型的引用需要初始化程序”?