2016-10-01 75 views
0

有时当我想打开有关网页,联系人,创建或博客 页面此错误出现:费穆:blog.views.blog_postDetailView 我donnt知道为什么,但我认为它必须做我的urlpattterns 或他们的顺序。在这里我的代码。 感谢您的帮助和改进 非常感谢Django的页面没有找到404,费穆:blog.views.blog_postDetailView

mainurl

from django.conf.urls import url, include 
from django.contrib import admin 


from django.conf import settings 
from django.conf.urls.static import static 

from blog.views import AboutPageView, ContactPageView, blog_postCreateView 

urlpatterns = [ 

    url(r'^about/', AboutPageView.as_view(), name='about'), 
    url(r'^contact/', ContactPageView.as_view(), name='contact'), 
    url(r'^create/', blog_postCreateView.as_view(), name='blog_post_create'), 
    url(r'', include('blog.urls')), 
    url(r'^blog/', include('blog.urls')), 

    #admin and login 
    url(r'^admin/', admin.site.urls), 
    url(r'^accounts/', include('registration.backends.default.urls')), 

] 


if settings.DEBUG: 
    urlpatterns += static(settings.STATIC_URL, document_root=settings.STATIC_ROOT) 
    urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) 

博客网址

from django.conf.urls import url 

from .views import blog_postListView, blog_postDetailView, blog_postCreateView 

urlpatterns = [ 

    url(r'^$', blog_postListView.as_view(), name='blog_post_list'), 
    url(r'^(?P<slug>[-\w]+)$', blog_postDetailView.as_view(), name='blog_post_detail'), 
] 

基本HTML中,导航部分

<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> 
     <ul class="nav navbar-nav"> 
       <li> 
       <a href="/">Home</a> 
      </li> 
      <li> 
       <a href="{% url 'about' %}">About</a> 
      </li> 
      <li> 
       <a href="{% url 'contact' %}">Contact</a> 
      </li> 
      <li> 
       <a href="/blog">Blog</a> 
      </li> 
      <li> 
      {% if request.user.is_authenticated %} 
        <li><a href="{% url 'auth_logout' %}">Logout</a></li> 
       {% else %} 
       <li><a href="{% url 'auth_login' %}">Login</a></li> 
       <li><a href="{% url 'registration_register' %}">Register</a></li> 
      {% endif %} 

模型

rom __future__ import unicode_literals 

from django.conf import settings 
from django.core.urlresolvers import reverse 
from django.db import models 

from django.db.models.signals import pre_save, post_save 
from django.utils.text import slugify 
# Create your models here. 





def upload_location(instance, filename): 
    #filebase, extension = filename.split(".") 
    #return "%s/%s.%s" %(instance.id, instance.id, extension) 
    return "%s/%s" %(instance.id, filename) 


class blog_post(models.Model): 
    user = models.ForeignKey(settings.AUTH_USER_MODEL, default=1) 
    title = models.CharField(max_length=120) 
    height_field = models.IntegerField(default=0) 
    width_field = models.IntegerField(default=0) 
    image = models.ImageField(upload_to=upload_location, null=True, blank=True, width_field="width_field", height_field="height_field") 
    #height_field = models.PositiveIntegerField() 
    #width_field = models.PositiveIntegerField() 
    slug = models.SlugField(unique=True) 
    content = models.TextField() 
    updated = models.DateTimeField(auto_now=True, auto_now_add=False) 
    timestamp = models.DateTimeField(auto_now=False, auto_now_add=True) 

    def __unicode__(self): 
     return self.title 

    def __str__(self): 
     return self.title 

    def get_absolute_url(self): 
     return reverse("blog_post_detail", kwargs={"slug": self.slug}) 


def create_slug(instance, new_slug=None): 
    slug = slugify(instance.title) 
    if new_slug is not None: 
     slug = new_slug 
    qs = blog_post.objects.filter(slug=slug).order_by("-id") 
    exists = qs.exists() 
    if exists: 
     new_slug = "%s-%s" %(slug, qs.first().id) 
     return create_slug(instance, new_slug=new_slug) 
    return slug 


def pre_save_post_receiver(sender, instance, *args, **kwargs): 
    if not instance.slug: 
     instance.slug = create_slug(instance) 



pre_save.connect(pre_save_post_receiver, sender=blog_post) 

意见

from django.contrib.auth.decorators import login_required 
from django.core.urlresolvers import reverse 
from django.http import HttpResponse 
from django.views.generic import View 
from django.views.generic.base import TemplateView, TemplateResponseMixin, ContextMixin 
from django.views.generic.detail import DetailView 
from django.views.generic.list import ListView 
from django.views.generic.edit import CreateView, UpdateView, DeleteView 
from django.shortcuts import render 
from django.utils.decorators import method_decorator 




from .models import blog_post 
from .forms import blog_postForm 
# Create your views here. 


class LoginRequiredMixin(object): 
    @classmethod 
    def as_view(cls, **kwargs): 
     view = super(LoginRequiredMixin, cls).as_view(**kwargs) 
     return login_required(view) 

    #@method_decorator(login_required) 
    #def dispatch(self, request, *args, **kwargs): 
    # return super(LoginRequiredMixin, self).dispatch(request, *args, **kwargs) 



class blog_postCreateView(LoginRequiredMixin, CreateView): 
    #model = blog_post 
    form_class = blog_postForm 
    template_name = "form.html" 
    #fields = ["title", "content"] 
    def get_success_url(self): 
     return reverse("blog_post_list") 

    # @method_decorator(login_required) 
    # def dispatch(self, request, *args, **kwargs): 
    # return super(MyView, self).dispatch(request, *args, **kwargs)  


class blog_postListView(ListView): 

    model = blog_post 
    def get_queryset(self, *args, **kwargs): 
     qs = super(blog_postListView, self).get_queryset(*args, **kwargs).order_by("-timestamp") 
     return qs 

class blog_postDetailView(DetailView): 

    model = blog_post 

class AboutPageView(TemplateView): 

    template_name = "about.html" 


class ContactPageView(TemplateView): 

    template_name = "contact.html" 

更新网址

from django.conf.urls import url, include 
from django.contrib import admin 


from django.conf import settings 
from django.conf.urls.static import static 

from blog.views import AboutPageView, ContactPageView, blog_postCreateView 

urlpatterns = [ 

    url(r'^about/', AboutPageView.as_view(), name='about'), 
    url(r'^contact/', ContactPageView.as_view(), name='contact'), 
    url(r'^create/', blog_postCreateView.as_view(), name='blog_post_create'), 
    url(r'^categories/', include('blog.urls_categories')), 
    #url(r'', include('blog.urls')), 
    url(r'^blog/', include('blog.urls')), 

    #admin and login 
    url(r'^admin/', admin.site.urls), 
    url(r'^accounts/', include('registration.backends.default.urls')), 
    url(r'', include('blog.urls')), 

] 


if settings.DEBUG: 
    urlpatterns += static(settings.STATIC_URL, document_root=settings.STATIC_ROOT) 
    urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) 

回答

0

把下面一行在结束url_patterns列表像

urlpatterns = [ 
    #all other urls, 
    url(r'', include('blog.urls')), 
] 

OR

url(r'^blogdetail/', include('blog.urls')), 
+0

您好,感谢您的帮助, 所有页面的工作,除了建立和博客的“博客”页面, 请你会这么好心,并解释为什么它应该工作,然后, 原因改变了顺序或代替使用blogdetail,博客链接的模板标签是什么?非常感谢 –

+0

发布您更新的urls.py. – itzMEonTV

+0

好的谢谢你,像这样的顺序,它适用于我:) 我发布了上面的更新网址,可以解释它为什么可行, 当我把网址到底? –