Использование {% url ??? %} в шаблонах django

Я много искал в Google ответы о том, как использовать тег url в шаблонах, только чтобы найти множество ответов, в которых говорилось: «Просто вставьте его в свой шаблон и укажите в нужном вам виде. URL для '. Что ж, мне не повезло :( Я пробовал все возможные варианты и прибегал к публикации здесь в крайнем случае.

Итак, вот оно. Мой urls.py выглядит так:

from django.conf.urls.defaults import *
from login.views import *
from mainapp.views import *
import settings

# Uncomment the next two lines to enable the admin:
from django.contrib import admin
admin.autodiscover()

urlpatterns = patterns('',
    # Example:
    # (r'^weclaim/', include('weclaim.foo.urls')),
    (r'^login/', login_view),
    (r'^logout/', logout_view),
    ('^$', main_view),

    # Uncomment the admin/doc line below and add 'django.contrib.admindocs' 
    # to INSTALLED_APPS to enable admin documentation:
    # (r'^admin/doc/', include('django.contrib.admindocs.urls')),

    # Uncomment the next line to enable the admin:
    (r'^admin/', include(admin.site.urls)),
    #(r'^static/(?P<path>.*)$', 'django.views.static.serve',{'document_root': '/home/arthur/Software/django/weclaim/templates/static'}),
    (r'^static/(?P<path>.*)$', 'django.views.static.serve',{'document_root': settings.MEDIA_ROOT}),
)

Мой 'views.py' в мой каталог 'login' выглядит так:

from django.shortcuts import render_to_response, redirect
from django.template import RequestContext
from django.contrib import auth

def login_view(request):
    if request.method == 'POST':
        uname = request.POST.get('username', '')
        psword = request.POST.get('password', '')
        user = auth.authenticate(username=uname, password=psword)
        # if the user logs in and is active
        if user is not None and user.is_active:
            auth.login(request, user)
            return render_to_response('main/main.html', {}, context_instance=RequestContext(request))
            #return redirect(main_view)
        else:
            return render_to_response('loginpage.html', {'box_width': '402', 'login_failed': '1',}, context_instance=RequestContext(request))
    else:
        return render_to_response('loginpage.html', {'box_width': '400',}, context_instance=RequestContext(request))

def logout_view(request):
    auth.logout(request)
    return render_to_response('loginpage.html', {'box_width': '402', 'logged_out': '1',}, context_instance=RequestContext(request))

и, наконец, main.html, на который указывает login_view, выглядит так:

<html>
<body>
test! <a href="{% url logout_view %}">logout</a>
</body>
</html>

Итак, почему я получаю ' NoReverseMatch 'каждый раз?

* (немного другое примечание, мне пришлось использовать' context_instance = RequestContext (request) 'в конце всех моих запросов на рендеринг в ответ, потому что в противном случае он не распознал бы {{MEDIA_URL}} в мои шаблоны, и я не мог ссылаться ни на какие файлы css или js. Я не уверен, почему это так. Мне это не кажется правильным) *

70
задан Martijn Pieters 22 April 2014 в 15:03
поделиться