'staticfiles' is not a registered tag library. Must be one of: admin_list admin_modify admin_urls cache i18n l10n list_element log static tz
Request Method: | GET |
---|---|
Request URL: | http://dingauto.cn/news_info/list/2-1 |
Django Version: | 5.0.3 |
Exception Type: | TemplateSyntaxError |
Exception Value: | 'staticfiles' is not a registered tag library. Must be one of: admin_list admin_modify admin_urls cache i18n l10n list_element log static tz |
Exception Location: | /var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/defaulttags.py, line 1036, in find_library |
Raised during: | ding_site.views.news_list |
Python Executable: | /var/www/dingautosite/venv/bin/uwsgi |
Python Version: | 3.10.12 |
Python Path: | ['.', '', '/usr/lib/python310.zip', '/usr/lib/python3.10', '/usr/lib/python3.10/lib-dynload', '/var/www/dingautosite/venv/lib/python3.10/site-packages'] |
Server time: | Thu, 28 Mar 2024 18:16:34 +0000 |
In template /var/www/dingautosite/templates/news_list.html
, error at line 2
1 | {% extends "index.html" %} |
---|---|
2 | {% load staticfiles %} |
3 | {% block nav_link %} |
4 | <ul> |
5 | <li><a href="/">网站首页</a> |
6 | </li><li><a href="/products">公司产品</a> |
7 | </li><li class="on"><a href="/news_info/1">新闻资讯</a> |
8 | </li><li><a href="/about_us">关于我们</a> </li> |
9 | </ul> |
10 | {% endblock %} |
11 | {% block article %} |
12 | <section id="pro_big_pic" class="container"> |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/defaulttags.py
, line 1034, in find_library
nodelist_false = NodeList()
values = [parser.compile_filter(bit) for bit in bits[1:]]
return IfChangedNode(nodelist_true, nodelist_false, *values)
def find_library(parser, name):
try:
return parser.libraries[name]…
except KeyError:
raise TemplateSyntaxError(
"'%s' is not a registered tag library. Must be one of:\n%s"
% (
name,
"\n".join(sorted(parser.libraries)),
Variable | Value |
---|---|
name | 'staticfiles' |
parser | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/core/handlers/exception.py
, line 55, in inner
return inner
else:
@wraps(get_response)
def inner(request):
try:
response = get_response(request)…
except Exception as exc:
response = response_for_exception(request, exc)
return response
return inner
Variable | Value |
---|---|
exc | TemplateSyntaxError("'staticfiles' is not a registered tag library. Must be one of:\nadmin_list\nadmin_modify\nadmin_urls\ncache\ni18n\nl10n\nlist_element\nlog\nstatic\ntz") |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f4a64761420>> |
request | <WSGIRequest: GET '/news_info/list/2-1'> |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/core/handlers/base.py
, line 197, in _get_response
if response is None:
wrapped_callback = self.make_view_atomic(callback)
# If it is an asynchronous view, run it in a subthread.
if iscoroutinefunction(wrapped_callback):
wrapped_callback = async_to_sync(wrapped_callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)…
except Exception as e:
response = self.process_exception_by_middleware(e, request)
if response is None:
raise
# Complain if the view returned None (a common error).
Variable | Value |
---|---|
callback | <function news_list at 0x7f4a643c6f80> |
callback_args | () |
callback_kwargs | {'category_on': '2', 'page_on': '1'} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <CsrfViewMiddleware get_response=convert_exception_to_response.<locals>.inner>> |
request | <WSGIRequest: GET '/news_info/list/2-1'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f4a64761420> |
wrapped_callback | <function news_list at 0x7f4a643c6f80> |
/var/www/dingautosite/./ding_site/views.py
, line 86, in news_list
try:
page = page_on
article_list = paginator.page(page)
except (EmptyPage, InvalidPage, PageNotAnInteger):
article_list = paginator.page(1)
except Exception as e:
pass
return render(req, 'news_list.html', locals())…
def news_content(req, category_on, page, nth):
category_on = int(category_on)
page = int(page)
nth = int(nth)
Variable | Value |
---|---|
article_list | <Page 1 of 1> |
category_list | <QuerySet [<Category: 企业动态>, <Category: 行业动态>, <Category: 媒体报道>]> |
category_on | '2' |
page | '1' |
page_on | '1' |
paginator | <django.core.paginator.Paginator object at 0x7f4a65eb89a0> |
req | <WSGIRequest: GET '/news_info/list/2-1'> |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/shortcuts.py
, line 25, in render
def render(
request, template_name, context=None, content_type=None, status=None, using=None
):
"""
Return an HttpResponse whose content is filled with the result of calling
django.template.loader.render_to_string() with the passed arguments.
"""
content = loader.render_to_string(template_name, context, request, using=using)…
return HttpResponse(content, content_type, status)
def redirect(to, *args, permanent=False, **kwargs):
"""
Return an HttpResponseRedirect to the appropriate URL for the arguments
Variable | Value |
---|---|
content_type | None |
context | {'article_list': <Page 1 of 1>, 'category_list': <QuerySet [<Category: 企业动态>, <Category: 行业动态>, <Category: 媒体报道>]>, 'category_on': '2', 'page': '1', 'page_on': '1', 'paginator': <django.core.paginator.Paginator object at 0x7f4a65eb89a0>, 'req': <WSGIRequest: GET '/news_info/list/2-1'>} |
request | <WSGIRequest: GET '/news_info/list/2-1'> |
status | None |
template_name | 'news_list.html' |
using | None |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/loader.py
, line 61, in render_to_string
Load a template and render it with a context. Return a string.
template_name may be a string or a list of strings.
"""
if isinstance(template_name, (list, tuple)):
template = select_template(template_name, using=using)
else:
template = get_template(template_name, using=using)…
return template.render(context, request)
def _engine_list(using=None):
return engines.all() if using is None else [engines[using]]
Variable | Value |
---|---|
context | {'article_list': <Page 1 of 1>, 'category_list': <QuerySet [<Category: 企业动态>, <Category: 行业动态>, <Category: 媒体报道>]>, 'category_on': '2', 'page': '1', 'page_on': '1', 'paginator': <django.core.paginator.Paginator object at 0x7f4a65eb89a0>, 'req': <WSGIRequest: GET '/news_info/list/2-1'>} |
request | <WSGIRequest: GET '/news_info/list/2-1'> |
template_name | 'news_list.html' |
using | None |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/loader.py
, line 15, in get_template
Raise TemplateDoesNotExist if no such template exists.
"""
chain = []
engines = _engine_list(using)
for engine in engines:
try:
return engine.get_template(template_name)…
except TemplateDoesNotExist as e:
chain.append(e)
raise TemplateDoesNotExist(template_name, chain=chain)
Variable | Value |
---|---|
chain | [] |
engine | <django.template.backends.django.DjangoTemplates object at 0x7f4a642f38e0> |
engines | [<django.template.backends.django.DjangoTemplates object at 0x7f4a642f38e0>] |
template_name | 'news_list.html' |
using | None |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/backends/django.py
, line 33, in get_template
self.engine = Engine(self.dirs, self.app_dirs, **options)
def from_string(self, template_code):
return Template(self.engine.from_string(template_code), self)
def get_template(self, template_name):
try:
return Template(self.engine.get_template(template_name), self)…
except TemplateDoesNotExist as exc:
reraise(exc, self)
def get_templatetag_libraries(self, custom_libraries):
"""
Return a collation of template tag libraries from installed
Variable | Value |
---|---|
self | <django.template.backends.django.DjangoTemplates object at 0x7f4a642f38e0> |
template_name | 'news_list.html' |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/engine.py
, line 177, in get_template
return Template(template_code, engine=self)
def get_template(self, template_name):
"""
Return a compiled Template object for the given template name,
handling template inheritance recursively.
"""
template, origin = self.find_template(template_name)…
if not hasattr(template, "render"):
# template needs to be compiled
template = Template(template, origin, template_name, engine=self)
return template
def render_to_string(self, template_name, context=None):
Variable | Value |
---|---|
self | <Engine: dirs=['/var/www/dingautosite/templates'] app_dirs=True context_processors=['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages'] debug=True loaders=[('django.template.loaders.cached.Loader', ['django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader'])] string_if_invalid='' file_charset='utf-8' libraries={'cache': 'django.templatetags.cache', 'i18n': 'django.templatetags.i18n', 'l10n': 'django.templatetags.l10n', 'static': 'django.templatetags.static', 'tz': 'django.templatetags.tz', 'admin_list': 'django.contrib.admin.templatetags.admin_list', 'admin_modify': 'django.contrib.admin.templatetags.admin_modify', 'admin_urls': 'django.contrib.admin.templatetags.admin_urls', 'log': 'django.contrib.admin.templatetags.log', 'list_element': 'ding_site.templatetags.list_element'} builtins=['django.template.defaulttags', 'django.template.defaultfilters', 'django.template.loader_tags'] autoescape=True> |
template_name | 'news_list.html' |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/engine.py
, line 159, in find_template
"Invalid value in template loaders configuration: %r" % loader
)
def find_template(self, name, dirs=None, skip=None):
tried = []
for loader in self.template_loaders:
try:
template = loader.get_template(name, skip=skip)…
return template, template.origin
except TemplateDoesNotExist as e:
tried.extend(e.tried)
raise TemplateDoesNotExist(name, tried=tried)
def from_string(self, template_code):
Variable | Value |
---|---|
dirs | None |
loader | <django.template.loaders.cached.Loader object at 0x7f4a636a1060> |
name | 'news_list.html' |
self | <Engine: dirs=['/var/www/dingautosite/templates'] app_dirs=True context_processors=['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages'] debug=True loaders=[('django.template.loaders.cached.Loader', ['django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader'])] string_if_invalid='' file_charset='utf-8' libraries={'cache': 'django.templatetags.cache', 'i18n': 'django.templatetags.i18n', 'l10n': 'django.templatetags.l10n', 'static': 'django.templatetags.static', 'tz': 'django.templatetags.tz', 'admin_list': 'django.contrib.admin.templatetags.admin_list', 'admin_modify': 'django.contrib.admin.templatetags.admin_modify', 'admin_urls': 'django.contrib.admin.templatetags.admin_urls', 'log': 'django.contrib.admin.templatetags.log', 'list_element': 'ding_site.templatetags.list_element'} builtins=['django.template.defaulttags', 'django.template.defaultfilters', 'django.template.loader_tags'] autoescape=True> |
skip | None |
tried | [] |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/loaders/cached.py
, line 57, in get_template
if isinstance(cached, type) and issubclass(cached, TemplateDoesNotExist):
raise cached(template_name)
elif isinstance(cached, TemplateDoesNotExist):
raise copy_exception(cached)
return cached
try:
template = super().get_template(template_name, skip)…
except TemplateDoesNotExist as e:
self.get_template_cache[key] = (
copy_exception(e) if self.engine.debug else TemplateDoesNotExist
)
raise
else:
Variable | Value |
---|---|
__class__ | <class 'django.template.loaders.cached.Loader'> |
cached | None |
key | 'news_list.html' |
self | <django.template.loaders.cached.Loader object at 0x7f4a636a1060> |
skip | None |
template_name | 'news_list.html' |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/loaders/base.py
, line 28, in get_template
try:
contents = self.get_contents(origin)
except TemplateDoesNotExist:
tried.append((origin, "Source does not exist"))
continue
else:
return Template(…
contents,
origin,
origin.template_name,
self.engine,
)
Variable | Value |
---|---|
contents | ('{% extends "index.html" %}\n' '{% load staticfiles %}\n' '{% block nav_link %}\n' ' <ul>\n' ' <li><a href="/">网站首页</a>\n' ' </li><li><a href="/products">公司产品</a>\n' ' </li><li class="on"><a href="/news_info/1">新闻资讯</a>\n' ' </li><li><a href="/about_us">关于我们</a> </li>\n' ' </ul>\n' '{% endblock %}\n' '{% block article %}\n' '<section id="pro_big_pic" class="container">\n' '</section>\n' '<section id="news_" class="container section_2">\n' ' <h1 class="_h1">新闻资讯</h1>\n' ' <hr class="h1_hr">\n' ' <div class="container">\n' ' <div id="news_ca">\n' ' <ul>\n' " {% for i in category_list%}{% if i.index|add:'0' == " "category_on|add:'0' %}<li\n" ' class="news_on"><a href="{% url \'news_list\' ' 'i.index page_on %}"\n' ' >{{ i.name }}</a></li>{% else %}<li\n' ' ><a href="{% url \'news_list\' i.index 0 %}"\n' ' >{{ i.name }}</a></li>{% endif %}{% endfor %}\n' ' </ul>\n' ' </div>\n' " {% include 'pagenation.html' %}\n" ' </div>\n' '</section>\n' '{% endblock %}') |
origin | <Origin name='/var/www/dingautosite/templates/news_list.html'> |
self | <django.template.loaders.cached.Loader object at 0x7f4a636a1060> |
skip | None |
template_name | 'news_list.html' |
tried | [] |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/base.py
, line 154, in __init__
engine = Engine.get_default()
if origin is None:
origin = Origin(UNKNOWN_SOURCE)
self.name = name
self.origin = origin
self.engine = engine
self.source = str(template_string) # May be lazy.
self.nodelist = self.compile_nodelist()…
def __repr__(self):
return '<%s template_string="%s...">' % (
self.__class__.__qualname__,
self.source[:20].replace("\n", ""),
)
Variable | Value |
---|---|
engine | <Engine: dirs=['/var/www/dingautosite/templates'] app_dirs=True context_processors=['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages'] debug=True loaders=[('django.template.loaders.cached.Loader', ['django.template.loaders.filesystem.Loader', 'django.template.loaders.app_directories.Loader'])] string_if_invalid='' file_charset='utf-8' libraries={'cache': 'django.templatetags.cache', 'i18n': 'django.templatetags.i18n', 'l10n': 'django.templatetags.l10n', 'static': 'django.templatetags.static', 'tz': 'django.templatetags.tz', 'admin_list': 'django.contrib.admin.templatetags.admin_list', 'admin_modify': 'django.contrib.admin.templatetags.admin_modify', 'admin_urls': 'django.contrib.admin.templatetags.admin_urls', 'log': 'django.contrib.admin.templatetags.log', 'list_element': 'ding_site.templatetags.list_element'} builtins=['django.template.defaulttags', 'django.template.defaultfilters', 'django.template.loader_tags'] autoescape=True> |
name | 'news_list.html' |
origin | <Origin name='/var/www/dingautosite/templates/news_list.html'> |
self | <Template template_string="{% extends "index.ht..."> |
template_string | ('{% extends "index.html" %}\n' '{% load staticfiles %}\n' '{% block nav_link %}\n' ' <ul>\n' ' <li><a href="/">网站首页</a>\n' ' </li><li><a href="/products">公司产品</a>\n' ' </li><li class="on"><a href="/news_info/1">新闻资讯</a>\n' ' </li><li><a href="/about_us">关于我们</a> </li>\n' ' </ul>\n' '{% endblock %}\n' '{% block article %}\n' '<section id="pro_big_pic" class="container">\n' '</section>\n' '<section id="news_" class="container section_2">\n' ' <h1 class="_h1">新闻资讯</h1>\n' ' <hr class="h1_hr">\n' ' <div class="container">\n' ' <div id="news_ca">\n' ' <ul>\n' " {% for i in category_list%}{% if i.index|add:'0' == " "category_on|add:'0' %}<li\n" ' class="news_on"><a href="{% url \'news_list\' ' 'i.index page_on %}"\n' ' >{{ i.name }}</a></li>{% else %}<li\n' ' ><a href="{% url \'news_list\' i.index 0 %}"\n' ' >{{ i.name }}</a></li>{% endif %}{% endfor %}\n' ' </ul>\n' ' </div>\n' " {% include 'pagenation.html' %}\n" ' </div>\n' '</section>\n' '{% endblock %}') |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/base.py
, line 196, in compile_nodelist
tokens,
self.engine.template_libraries,
self.engine.template_builtins,
self.origin,
)
try:
return parser.parse()…
except Exception as e:
if self.engine.debug:
e.template_debug = self.get_exception_info(e, e.token)
raise
def get_exception_info(self, exception, token):
Variable | Value |
---|---|
lexer | <DebugLexer template_string="{% extends "index.ht...", verbatim=False> |
parser | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
self | <Template template_string="{% extends "index.ht..."> |
tokens | [<Block token: "extends "index.html"...">, <Text token: "...">, <Block token: "load staticfiles...">, <Text token: "...">, <Block token: "block nav_link...">, <Text token: " <ul> <l...">, <Block token: "endblock...">, <Text token: "...">, <Block token: "block article...">, <Text token: "<section id="pro_bi...">, <Block token: "for i in category_li...">, <Block token: "if i.index|add:'0' =...">, <Text token: "<li ...">, <Block token: "url 'news_list' i.in...">, <Text token: "" >...">, <Var token: "i.name...">, <Text token: "</a></li>...">, <Block token: "else...">, <Text token: "<li ...">, <Block token: "url 'news_list' i.in...">, <Text token: "" >...">, <Var token: "i.name...">, <Text token: "</a></li>...">, <Block token: "endif...">, <Block token: "endfor...">, <Text token: " </ul> ...">, <Block token: "include 'pagenation....">, <Text token: " </div></sectio...">, <Block token: "endblock...">] |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/base.py
, line 510, in parse
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)
except Exception as e:
raise self.error(token, e)…
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
self.unclosed_block_tag(parse_until)
return nodelist
Variable | Value |
---|---|
command | 'extends' |
compile_func | <function do_extends at 0x7f4a6476edd0> |
nodelist | [] |
parse_until | [] |
self | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
token | <Block token: "extends "index.html"..."> |
token_type | 2 |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/base.py
, line 508, in parse
try:
compile_func = self.tags[command]
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)…
except Exception as e:
raise self.error(token, e)
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
Variable | Value |
---|---|
command | 'extends' |
compile_func | <function do_extends at 0x7f4a6476edd0> |
nodelist | [] |
parse_until | [] |
self | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
token | <Block token: "extends "index.html"..."> |
token_type | 2 |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/loader_tags.py
, line 295, in do_extends
the parent template itself (if it evaluates to a Template object).
"""
bits = token.split_contents()
if len(bits) != 2:
raise TemplateSyntaxError("'%s' takes one argument" % bits[0])
bits[1] = construct_relative_path(parser.origin.template_name, bits[1])
parent_name = parser.compile_filter(bits[1])
nodelist = parser.parse()…
if nodelist.get_nodes_by_type(ExtendsNode):
raise TemplateSyntaxError(
"'%s' cannot appear more than once in the same template" % bits[0]
)
return ExtendsNode(nodelist, parent_name)
Variable | Value |
---|---|
bits | ['extends', '"index.html"'] |
parent_name | <FilterExpression '"index.html"'> |
parser | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
token | <Block token: "extends "index.html"..."> |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/base.py
, line 510, in parse
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)
except Exception as e:
raise self.error(token, e)…
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
self.unclosed_block_tag(parse_until)
return nodelist
Variable | Value |
---|---|
command | 'load' |
compile_func | <function load at 0x7f4a6476c820> |
nodelist | [<TextNode: '\n'>] |
parse_until | [] |
self | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
token | <Block token: "load staticfiles..."> |
token_type | 2 |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/base.py
, line 508, in parse
try:
compile_func = self.tags[command]
except KeyError:
self.invalid_block_tag(token, command, parse_until)
# Compile the callback into a node object and add it to
# the node list.
try:
compiled_result = compile_func(self, token)…
except Exception as e:
raise self.error(token, e)
self.extend_nodelist(nodelist, compiled_result, token)
# Compile success. Remove the token from the command stack.
self.command_stack.pop()
if parse_until:
Variable | Value |
---|---|
command | 'load' |
compile_func | <function load at 0x7f4a6476c820> |
nodelist | [<TextNode: '\n'>] |
parse_until | [] |
self | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
token | <Block token: "load staticfiles..."> |
token_type | 2 |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/defaulttags.py
, line 1096, in load
name = bits[-1]
lib = find_library(parser, name)
subset = load_from_library(lib, name, bits[1:-2])
parser.add_library(subset)
else:
# one or more libraries are specified; load and add them to the parser
for name in bits[1:]:
lib = find_library(parser, name)…
parser.add_library(lib)
return LoadNode()
@register.tag
def lorem(parser, token):
Variable | Value |
---|---|
bits | ['load', 'staticfiles'] |
name | 'staticfiles' |
parser | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
token | <Block token: "load staticfiles..."> |
/var/www/dingautosite/venv/lib/python3.10/site-packages/django/template/defaulttags.py
, line 1036, in find_library
return IfChangedNode(nodelist_true, nodelist_false, *values)
def find_library(parser, name):
try:
return parser.libraries[name]
except KeyError:
raise TemplateSyntaxError(…
"'%s' is not a registered tag library. Must be one of:\n%s"
% (
name,
"\n".join(sorted(parser.libraries)),
),
)
Variable | Value |
---|---|
name | 'staticfiles' |
parser | <Parser tokens=[<Block token: "endblock...">, <Text token: " </div></sectio...">, <Block token: "include 'pagenation....">, <Text token: " </ul> ...">, <Block token: "endfor...">, <Block token: "endif...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "else...">, <Text token: "</a></li>...">, <Var token: "i.name...">, <Text token: "" >...">, <Block token: "url 'news_list' i.in...">, <Text token: "<li ...">, <Block token: "if i.index|add:'0' =...">, <Block token: "for i in category_li...">, <Text token: "<section id="pro_bi...">, <Block token: "block article...">, <Text token: "...">, <Block token: "endblock...">, <Text token: " <ul> <l...">, <Block token: "block nav_link...">, <Text token: "...">]> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
CONTENT_LENGTH | '' |
CONTENT_TYPE | '' |
DOCUMENT_ROOT | '/usr/share/nginx/html' |
HTTP_ACCEPT | '*/*' |
HTTP_HOST | 'dingauto.cn' |
HTTP_USER_AGENT | 'claudebot' |
PATH_INFO | '/news_info/list/2-1' |
QUERY_STRING | '' |
REMOTE_ADDR | '34.201.122.150' |
REMOTE_PORT | '32790' |
REQUEST_METHOD | 'GET' |
REQUEST_SCHEME | 'http' |
REQUEST_URI | '/news_info/list/2-1' |
SCRIPT_NAME | '' |
SERVER_NAME | 'www.dingauto.cn' |
SERVER_PORT | '80' |
SERVER_PROTOCOL | 'HTTP/1.1' |
uwsgi.node | b'iZuf6gswx6d8u1gky0mh4kZ' |
uwsgi.version | b'2.0.24' |
wsgi.errors | <_io.TextIOWrapper name=2 mode='w' encoding='UTF-8'> |
wsgi.file_wrapper | <built-in function uwsgi_sendfile> |
wsgi.input | <uwsgi._Input object at 0x7f4a6361f0d0> |
wsgi.multiprocess | False |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'http' |
wsgi.version | (1, 0) |
dingautosite.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['www.dingauto.cn', 'dingauto.cn', '127.0.0.1'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | '/var/www/dingautosite' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SAMESITE | 'Lax' |
CSRF_COOKIE_SECURE | False |
CSRF_FAILURE_VIEW | 'django.views.csrf.csrf_failure' |
CSRF_HEADER_NAME | 'HTTP_X_CSRFTOKEN' |
CSRF_TRUSTED_ORIGINS | [] |
CSRF_USE_SESSIONS | False |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_HEALTH_CHECKS': False, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.db.backends.sqlite3', 'HOST': '', 'NAME': '/var/www/dingautosite/db.sqlite3', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': ''}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
DATA_UPLOAD_MAX_NUMBER_FILES | 100 |
DATETIME_FORMAT | 'N j, Y, P' |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M'] |
DATE_FORMAT | 'N j, Y' |
DATE_INPUT_FORMATS | ['%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y', '%b %d, %Y', '%d %b %Y', '%d %b, %Y', '%B %d %Y', '%B %d, %Y', '%d %B %Y', '%d %B, %Y'] |
DEBUG | True |
DEBUG_PROPAGATE_EXCEPTIONS | False |
DECIMAL_SEPARATOR | '.' |
DEFAULT_AUTO_FIELD | 'django.db.models.AutoField' |
DEFAULT_CHARSET | 'utf-8' |
DEFAULT_EXCEPTION_REPORTER | 'django.views.debug.ExceptionReporter' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'django.core.files.storage.FileSystemStorage' |
DEFAULT_FROM_EMAIL | 'webmaster@localhost' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'localhost' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | '' |
EMAIL_PORT | 25 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | False |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler'] |
FILE_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
FILE_UPLOAD_PERMISSIONS | 420 |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORMS_URLFIELD_ASSUME_HTTPS | False |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'ding_site.apps.DingSiteConfig'] |
INTERNAL_IPS | [] |
LANGUAGES | [('af', 'Afrikaans'), ('ar', 'Arabic'), ('ar-dz', 'Algerian Arabic'), ('ast', 'Asturian'), ('az', 'Azerbaijani'), ('bg', 'Bulgarian'), ('be', 'Belarusian'), ('bn', 'Bengali'), ('br', 'Breton'), ('bs', 'Bosnian'), ('ca', 'Catalan'), ('ckb', 'Central Kurdish (Sorani)'), ('cs', 'Czech'), ('cy', 'Welsh'), ('da', 'Danish'), ('de', 'German'), ('dsb', 'Lower Sorbian'), ('el', 'Greek'), ('en', 'English'), ('en-au', 'Australian English'), ('en-gb', 'British English'), ('eo', 'Esperanto'), ('es', 'Spanish'), ('es-ar', 'Argentinian Spanish'), ('es-co', 'Colombian Spanish'), ('es-mx', 'Mexican Spanish'), ('es-ni', 'Nicaraguan Spanish'), ('es-ve', 'Venezuelan Spanish'), ('et', 'Estonian'), ('eu', 'Basque'), ('fa', 'Persian'), ('fi', 'Finnish'), ('fr', 'French'), ('fy', 'Frisian'), ('ga', 'Irish'), ('gd', 'Scottish Gaelic'), ('gl', 'Galician'), ('he', 'Hebrew'), ('hi', 'Hindi'), ('hr', 'Croatian'), ('hsb', 'Upper Sorbian'), ('hu', 'Hungarian'), ('hy', 'Armenian'), ('ia', 'Interlingua'), ('id', 'Indonesian'), ('ig', 'Igbo'), ('io', 'Ido'), ('is', 'Icelandic'), ('it', 'Italian'), ('ja', 'Japanese'), ('ka', 'Georgian'), ('kab', 'Kabyle'), ('kk', 'Kazakh'), ('km', 'Khmer'), ('kn', 'Kannada'), ('ko', 'Korean'), ('ky', 'Kyrgyz'), ('lb', 'Luxembourgish'), ('lt', 'Lithuanian'), ('lv', 'Latvian'), ('mk', 'Macedonian'), ('ml', 'Malayalam'), ('mn', 'Mongolian'), ('mr', 'Marathi'), ('ms', 'Malay'), ('my', 'Burmese'), ('nb', 'Norwegian Bokmål'), ('ne', 'Nepali'), ('nl', 'Dutch'), ('nn', 'Norwegian Nynorsk'), ('os', 'Ossetic'), ('pa', 'Punjabi'), ('pl', 'Polish'), ('pt', 'Portuguese'), ('pt-br', 'Brazilian Portuguese'), ('ro', 'Romanian'), ('ru', 'Russian'), ('sk', 'Slovak'), ('sl', 'Slovenian'), ('sq', 'Albanian'), ('sr', 'Serbian'), ('sr-latn', 'Serbian Latin'), ('sv', 'Swedish'), ('sw', 'Swahili'), ('ta', 'Tamil'), ('te', 'Telugu'), ('tg', 'Tajik'), ('th', 'Thai'), ('tk', 'Turkmen'), ('tr', 'Turkish'), ('tt', 'Tatar'), ('udm', 'Udmurt'), ('ug', 'Uyghur'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('uz', 'Uzbek'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'ckb', 'fa', 'ug', 'ur'] |
LANGUAGE_CODE | 'en-us' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_HTTPONLY | False |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LANGUAGE_COOKIE_SAMESITE | None |
LANGUAGE_COOKIE_SECURE | False |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '/var/www/dingautosite/uploads' |
MEDIA_URL | '/uploads/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware'] |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'dingautosite.urls' |
SECRET_KEY | '********************' |
SECRET_KEY_FALLBACKS | '********************' |
SECURE_CONTENT_TYPE_NOSNIFF | True |
SECURE_CROSS_ORIGIN_OPENER_POLICY | 'same-origin' |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_REFERRER_POLICY | 'same-origin' |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | False |
SERVER_EMAIL | 'root@localhost' |
SESSION_CACHE_ALIAS | 'default' |
SESSION_COOKIE_AGE | 1209600 |
SESSION_COOKIE_DOMAIN | None |
SESSION_COOKIE_HTTPONLY | True |
SESSION_COOKIE_NAME | 'sessionid' |
SESSION_COOKIE_PATH | '/' |
SESSION_COOKIE_SAMESITE | 'Lax' |
SESSION_COOKIE_SECURE | False |
SESSION_ENGINE | 'django.contrib.sessions.backends.db' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | False |
SESSION_FILE_PATH | None |
SESSION_SAVE_EVERY_REQUEST | False |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'dingautosite.settings' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
STATICFILES_DIRS | ['/var/www/dingautosite/static'] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | None |
STATIC_URL | '/static/' |
STORAGES | {'default': {'BACKEND': 'django.core.files.storage.FileSystemStorage'}, 'staticfiles': {'BACKEND': 'django.contrib.staticfiles.storage.StaticFilesStorage'}} |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/var/www/dingautosite/templates'], 'OPTIONS': {'context_processors': ['django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages']}}] |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'P' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'UTC' |
USE_I18N | True |
USE_L10N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'dingautosite.wsgi.application' |
X_FRAME_OPTIONS | 'DENY' |
YEAR_MONTH_FORMAT | 'F Y' |
You’re seeing this error because you have DEBUG = True
in your
Django settings file. Change that to False
, and Django will
display a standard page generated by the handler for this status code.