【问题标题】:Access request in django custom template tagsdjango自定义模板标签中的访问请求
【发布时间】:2011-01-10 17:48:59
【问题描述】:

我在 myapp_extras.py 中的代码:

from django import template

register = template.Library()

@register.inclusion_tag('new/userinfo.html')
def address():
    address = request.session['address']
    return {'address':address}

在“settings.py”中:

TEMPLATE_CONTEXT_PROCESSORS =(
    "django.core.context_processors.auth",
    "django.core.context_processors.debug",
    "django.core.context_processors.i18n",
    "django.core.context_processors.media",
    'django.core.context_processors.request'
)

但我得到了一个错误:

TemplateSyntaxError at /items/

Caught an exception while rendering: global name 'request' is not defined

Original Traceback (most recent call last):
  File "C:\Python25\lib\site-packages\django\template\debug.py", line 71, in render_node
    result = node.render(context)
  File "C:\Python25\lib\site-packages\django\template\__init__.py", line 915, in render
    dict = func(*args)
  File "C:\p4\projects\myproject\..\myproject\invoice\templatetags\myapp_extras.py", line 9, in address
    address = request.session['address']
NameError: global name 'request' is not defined

我引用了这个 In Django, is it possible to access the current user session from within a custom tag?.

【问题讨论】:

标签: python django django-templates django-custom-tags


【解决方案1】:

request 不是该范围内的变量。您必须首先从上下文中获取它。 Pass takes_context to the decorator and add context to the tag arguments.

像这样:

@register.inclusion_tag('new/userinfo.html', takes_context=True)
def address(context):
    request = context['request']
    address = request.session['address']
    return {'address':address}

【讨论】:

  • 看来我仍然收到错误 TemplateSyntaxError at / Caught an exception while rendering: 'request' Original Traceback (last recent call last): File "C:\Python25\lib\site-packages\django\ template\debug.py”,第 71 行,在 render_node 结果 = node.render(context) 文件“C:\Python25\lib\site-packages\django\template_init_.py”,第 936 行,在渲染 dict = func(*args) 文件“c:\...\myapp_extras.py”,第 7 行,在登录请求 = context['request'] 文件“C:\Python25\lib\site-packages\ django\template\context.py",第 44 行,在 getitem 中引发 KeyError(key) KeyError: 'request'
  • 我在这个页面中注意到docs.djangoproject.com/en/dev/ref/templates/api"DJANGO.CORE.CONTEXT_PROCESSORS.REQUEST 如果 TEMPLATE_CONTEXT_PROCESSORS 包含这个处理器,每个 RequestContext 都会包含一个变量请求,它是当前的 HttpRequest。注意这个处理器不是默认启用;您必须激活它。”我需要配置以激活请求处理器的地方
  • 为什么inclusion_tag会出现这种情况?
  • Django 中的 MVP 分离阻止它看到有关请求本身的任何信息,因此必须将它提供给标签。
  • 不要忘记在 settings.py 中将 django.template.context_processors.request 添加到 TEMPLATES 否则 request 将不会包含在 中上下文
【解决方案2】:

我已经尝试了上面的解决方案(来自 Ignacio Vazquez-Abrams),但在我发现上下文处理器仅适用于 RequestContext 包装类之前它实际上并没有工作。

所以在主视图方法中你应该添加以下行:

from django.template import RequestContext        
return render_to_response('index.html', {'form': form, }, 
                              context_instance = RequestContext(request))

【讨论】:

  • 确实,context_instance = RequestContext(request) 是缺失的部分。使用它!
  • 如果您将响应呈现到字符串/html,您可以不使用 RequestContext。 @register.simple_tag(takes_context = True) ,然后是def my_tag(context, ...) ... return render_to_response('index.html', {'form': form, }, context_instance = context)
【解决方案3】:

我是这样做的:

from django import template
register = template.Library()

def do_test_request(parser,token):
    try:
        tag_name = token.split_contents() # Not really useful
    except ValueError:
        raise template.TemplateSyntaxError("%r error" % token.contents.split()[0])
    return RequestTestNode()

class RequestTestNode(template.Node):
    def __init__(self,):
        self.request = template.Variable('request')
    def render(self, context):
        rqst = self.request.resolve(context)
        return "The URL is: %s" % rqst.get_full_path()

register.tag('test_request', do_test_request)

还有一个名为 resolve_variable 的函数,但已被弃用。

希望对你有帮助!

【讨论】:

    猜你喜欢
    • 2013-03-30
    • 1970-01-01
    • 2015-01-20
    • 2021-07-13
    • 2012-05-04
    • 2012-03-15
    • 2011-05-02
    • 1970-01-01
    相关资源
    最近更新 更多