Invalid filter: 'capitalize'
Request Method: | GET |
---|---|
Request URL: | http://115.28.228.57/partner |
Django Version: | 2.1.7 |
Exception Type: | TemplateSyntaxError |
Exception Value: | Invalid filter: 'capitalize' |
Exception Location: | /usr/local/lib/python3.5/dist-packages/django/template/base.py in find_filter, line 569 |
Python Executable: | /usr/local/bin/uwsgi |
Python Version: | 3.5.2 |
Python Path: | ['.', '', '/usr/lib/python35.zip', '/usr/lib/python3.5', '/usr/lib/python3.5/plat-x86_64-linux-gnu', '/usr/lib/python3.5/lib-dynload', '/usr/local/lib/python3.5/dist-packages', '/usr/lib/python3/dist-packages', '/usr/local/lib/python3.5/dist-packages/odf', '/usr/local/lib/python3.5/dist-packages/odf', '/usr/local/lib/python3.5/dist-packages/odf', '/usr/local/lib/python3.5/dist-packages/odf', '/usr/local/lib/python3.5/dist-packages/odf', '/usr/local/lib/python3.5/dist-packages/odf', '/usr/local/lib/python3.5/dist-packages/odf'] |
Server time: | 星期五, 29 三月 2024 20:16:28 +0800 |
In template /root/www/templates/mainApp/partner.html
, error at line 272
262 | |
---|---|
263 | |
264 | <div id="demo" class="container" style="margin-top: 150px; width: 800px; margin-bottom:250px;"> |
265 | <input v-model="search" class="form-control" placeholder="名称或类别搜索"> |
266 | |
267 | <table class="table table-striped"> |
268 | <thead> |
269 | <tr> |
270 | <th v-repeat="column: columns"> |
271 | <a href="#" v-on="click: sortBy(column)" v-class="active: sortKey == column"> |
272 | {{ column | capitalize }} |
273 | </a> |
274 | </th> |
275 | </tr> |
276 | </thead> |
277 | |
278 | <tbody> |
279 | <tr v-repeat="users | filterBy search | orderBy sortKey reverse"> |
280 | <td>{{ name }}</td> |
281 | <td><a href="{{ url }}">下载地址</a></td> |
282 | <td>{{ times }}</td> |
/usr/local/lib/python3.5/dist-packages/django/core/handlers/exception.py
in inner
This decorator is automatically applied to all middleware to ensure that
no middleware leaks an exception and that the next middleware in the stack
can rely on getting a response instead of an exception.
"""
@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("Invalid filter: 'capitalize'",) |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f7f4ed30748>> |
request | <WSGIRequest: GET '/partner'> |
/usr/local/lib/python3.5/dist-packages/django/core/handlers/base.py
in _get_response
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)
except Exception as e:
response = self.process_exception_by_middleware(e, request)...
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
view_name = callback.__name__
else: # CBV
Variable | Value |
---|---|
callback | <function partner at 0x7f7f4a03aea0> |
callback_args | () |
callback_kwargs | {} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f7f4f29e048>> |
request | <WSGIRequest: GET '/partner'> |
resolver | <URLResolver 'www.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=mainApp.views.partner, args=(), kwargs={}, url_name=partner, app_names=[], namespaces=[]) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f7f4ed30748> |
wrapped_callback | <function partner at 0x7f7f4a03aea0> |
/usr/local/lib/python3.5/dist-packages/django/core/handlers/base.py
in _get_response
response = middleware_method(request, callback, callback_args, callback_kwargs)
if response:
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)...
except Exception as e:
response = self.process_exception_by_middleware(e, request)
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
Variable | Value |
---|---|
callback | <function partner at 0x7f7f4a03aea0> |
callback_args | () |
callback_kwargs | {} |
middleware_method | <bound method CsrfViewMiddleware.process_view of <django.middleware.csrf.CsrfViewMiddleware object at 0x7f7f4f29e048>> |
request | <WSGIRequest: GET '/partner'> |
resolver | <URLResolver 'www.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=mainApp.views.partner, args=(), kwargs={}, url_name=partner, app_names=[], namespaces=[]) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f7f4ed30748> |
wrapped_callback | <function partner at 0x7f7f4a03aea0> |
./mainApp/views.py
in partner
def kanban(request):
return render(request, 'mainApp/kanban.html')
def app(request):
return render(request, 'mainApp/app.html')
def partner(request):
return render(request, 'mainApp/partner.html')...
def book(request):
return render(request, 'mainApp/book.html')
def planning(request):
Variable | Value |
---|---|
request | <WSGIRequest: GET '/partner'> |
/usr/local/lib/python3.5/dist-packages/django/shortcuts.py
in render
def render(request, template_name, context=None, content_type=None, status=None, using=None):
"""
Return a 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 | None |
request | <WSGIRequest: GET '/partner'> |
status | None |
template_name | 'mainApp/partner.html' |
using | None |
/usr/local/lib/python3.5/dist-packages/django/template/loader.py
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 | None |
request | <WSGIRequest: GET '/partner'> |
template_name | 'mainApp/partner.html' |
using | None |
/usr/local/lib/python3.5/dist-packages/django/template/loader.py
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 0x7f7f4a5f62e8> |
engines | [<django.template.backends.django.DjangoTemplates object at 0x7f7f4a5f62e8>] |
template_name | 'mainApp/partner.html' |
using | None |
/usr/local/lib/python3.5/dist-packages/django/template/backends/django.py
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 0x7f7f4a5f62e8> |
template_name | 'mainApp/partner.html' |
/usr/local/lib/python3.5/dist-packages/django/template/engine.py
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 | <django.template.engine.Engine object at 0x7f7f4fdf3588> |
template_name | 'mainApp/partner.html' |
/usr/local/lib/python3.5/dist-packages/django/template/engine.py
in find_template
raise ImproperlyConfigured(
"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.filesystem.Loader object at 0x7f7f49dd86a0> |
name | 'mainApp/partner.html' |
self | <django.template.engine.Engine object at 0x7f7f4fdf3588> |
skip | None |
tried | [] |
/usr/local/lib/python3.5/dist-packages/django/template/loaders/base.py
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,...
)
raise TemplateDoesNotExist(template_name, tried=tried)
def get_template_sources(self, template_name):
"""
Variable | Value |
---|---|
contents | ('<html lang="en">\n' ' <head>\n' '\n' ' <title>OpenERP_HK Odoo</title>\n' ' <link rel="stylesheet" type="text/css" href="/static/css/app_search.css" ' '/>\n' ' <script ' 'src="https://cdn.bootcdn.net/ajax/libs/vue/0.12.6/vue.js"></script>\n' ' <link rel="stylesheet" href="/static/index/css/index.css">\n' ' <link rel="stylesheet" href="/static/product/css/font-awesome.min.css" ' 'rel="stylesheet">\n' '\n' ' <script src="/static/product/js/jquery.min.js"></script>\n' ' <script src="/static/product/js/bootstrap.min.js"></script>\n' ' <link rel="stylesheet" href="/static/product/css/bootstrap.min.css">\n' ' \n' '\n' ' <!-- 移动端CSS -->\n' ' <link rel="stylesheet" href="/static/index/css/index-mobile.css">\n' '\n' '</head>\n' '\n' ' <!--[if lte IE 8]><style>.main{display:none;} .support-note ' '.note-ie{display:block;}</style><![endif]-->\n' ' \n' '<body>\n' '\n' '\n' ' <!-- 导航栏 -->\n' '<div class="nav">\n' ' <!-- 侧边栏按钮 -->\n' ' <div class="menu" click>\n' ' <img src="/static/index/img/menu.png" alt="">\n' ' <!-- 侧边栏 -->\n' ' <ul class="slider">\n' ' <li>\n' ' <div>\n' ' 产品\n' ' </div>\n' ' <img src="/static/index/img/prev.png" alt="" srcset="">\n' ' <ul>\n' ' <li>\n' ' 销售管理\n' ' <img src="/static/index/img/prev.png" alt="" ' 'srcset="">\n' ' <ul>\n' ' <li><a href="/app_pages/crm" ' 'style="position:relative; overflow:hidden; color: white;">CRM客户关系管理</a>\n' ' </li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">销售</a></li>\n' ' <li><a href="/app_pages/crm" style="color: ' 'white;">POS</a></li>\n' ' <li><a href="/app_pages/crm" style="color: ' 'white;">合同管理</a></li>\n' ' <li><a href="/app_pages/subscriptions" ' 'style="color: white;">订阅</a></li>\n' ' <li><a href="/app_pages/live_chat" style="color: ' 'white;">在线客服</a></li>\n' ' </ul>\n' ' </li>\n' ' <li>\n' ' 生产制造\n' ' <img src="/static/index/img/prev.png" alt="" ' 'srcset="">\n' ' <ul>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">MRP</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">PLM</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">设备维护</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">质量管理</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">主数据管理</a></li>\n' ' </ul>\n' ' </li>\n' ' <li>\n' ' 运营管理\n' ' <img src="/static/index/img/prev.png" alt="" ' 'srcset="">\n' ' <ul>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">采购管理</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">库存管理</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">工时表</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">服务台</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">条码管理</a></li>\n' ' </ul>\n' ' </li>\n' ' <li>\n' ' 供应链管理\n' ' <img src="/static/index/img/prev.png" alt="" ' 'srcset="">\n' ' <ul>\n' ' <li><a href="/... <trimmed 18516 bytes string> |
origin | <django.template.base.Origin object at 0x7f7f49071358> |
self | <django.template.loaders.filesystem.Loader object at 0x7f7f49dd86a0> |
skip | None |
template_name | 'mainApp/partner.html' |
tried | [] |
/usr/local/lib/python3.5/dist-packages/django/template/base.py
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 __iter__(self):
for node in self.nodelist:
yield from node
def _render(self, context):
Variable | Value |
---|---|
engine | <django.template.engine.Engine object at 0x7f7f4fdf3588> |
name | 'mainApp/partner.html' |
origin | <django.template.base.Origin object at 0x7f7f49071358> |
self | <django.template.base.Template object at 0x7f7f490715c0> |
template_string | ('<html lang="en">\n' ' <head>\n' '\n' ' <title>OpenERP_HK Odoo</title>\n' ' <link rel="stylesheet" type="text/css" href="/static/css/app_search.css" ' '/>\n' ' <script ' 'src="https://cdn.bootcdn.net/ajax/libs/vue/0.12.6/vue.js"></script>\n' ' <link rel="stylesheet" href="/static/index/css/index.css">\n' ' <link rel="stylesheet" href="/static/product/css/font-awesome.min.css" ' 'rel="stylesheet">\n' '\n' ' <script src="/static/product/js/jquery.min.js"></script>\n' ' <script src="/static/product/js/bootstrap.min.js"></script>\n' ' <link rel="stylesheet" href="/static/product/css/bootstrap.min.css">\n' ' \n' '\n' ' <!-- 移动端CSS -->\n' ' <link rel="stylesheet" href="/static/index/css/index-mobile.css">\n' '\n' '</head>\n' '\n' ' <!--[if lte IE 8]><style>.main{display:none;} .support-note ' '.note-ie{display:block;}</style><![endif]-->\n' ' \n' '<body>\n' '\n' '\n' ' <!-- 导航栏 -->\n' '<div class="nav">\n' ' <!-- 侧边栏按钮 -->\n' ' <div class="menu" click>\n' ' <img src="/static/index/img/menu.png" alt="">\n' ' <!-- 侧边栏 -->\n' ' <ul class="slider">\n' ' <li>\n' ' <div>\n' ' 产品\n' ' </div>\n' ' <img src="/static/index/img/prev.png" alt="" srcset="">\n' ' <ul>\n' ' <li>\n' ' 销售管理\n' ' <img src="/static/index/img/prev.png" alt="" ' 'srcset="">\n' ' <ul>\n' ' <li><a href="/app_pages/crm" ' 'style="position:relative; overflow:hidden; color: white;">CRM客户关系管理</a>\n' ' </li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">销售</a></li>\n' ' <li><a href="/app_pages/crm" style="color: ' 'white;">POS</a></li>\n' ' <li><a href="/app_pages/crm" style="color: ' 'white;">合同管理</a></li>\n' ' <li><a href="/app_pages/subscriptions" ' 'style="color: white;">订阅</a></li>\n' ' <li><a href="/app_pages/live_chat" style="color: ' 'white;">在线客服</a></li>\n' ' </ul>\n' ' </li>\n' ' <li>\n' ' 生产制造\n' ' <img src="/static/index/img/prev.png" alt="" ' 'srcset="">\n' ' <ul>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">MRP</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">PLM</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">设备维护</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">质量管理</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">主数据管理</a></li>\n' ' </ul>\n' ' </li>\n' ' <li>\n' ' 运营管理\n' ' <img src="/static/index/img/prev.png" alt="" ' 'srcset="">\n' ' <ul>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">采购管理</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">库存管理</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">工时表</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">服务台</a></li>\n' ' <li><a href="/app_pages/sales" style="color: ' 'white;">条码管理</a></li>\n' ' </ul>\n' ' </li>\n' ' <li>\n' ' 供应链管理\n' ' <img src="/static/index/img/prev.png" alt="" ' 'srcset="">\n' ' <ul>\n' ' <li><a href="/... <trimmed 18516 bytes string> |
/usr/local/lib/python3.5/dist-packages/django/template/base.py
in compile_nodelist
tokens = lexer.tokenize()
parser = Parser(
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 | <django.template.base.DebugLexer object at 0x7f7f490712b0> |
parser | <django.template.base.Parser object at 0x7f7f426d01d0> |
self | <django.template.base.Template object at 0x7f7f490715c0> |
tokens | [<django.template.base.Token object at 0x7f7f49071d30>, <django.template.base.Token object at 0x7f7f490716d8>, <django.template.base.Token object at 0x7f7f426d0c88>, <django.template.base.Token object at 0x7f7f426d0f28>, <django.template.base.Token object at 0x7f7f426d0d30>, <django.template.base.Token object at 0x7f7f426d0630>, <django.template.base.Token object at 0x7f7f49071898>] |
/usr/local/lib/python3.5/dist-packages/django/template/base.py
in parse
self.extend_nodelist(nodelist, TextNode(token.contents), token)
elif token.token_type.value == 1: # TokenType.VAR
if not token.contents:
raise self.error(token, 'Empty variable tag on line %d' % token.lineno)
try:
filter_expression = self.compile_filter(token.contents)
except TemplateSyntaxError as e:
raise self.error(token, e)...
var_node = VariableNode(filter_expression)
self.extend_nodelist(nodelist, var_node, token)
elif token.token_type.value == 2: # TokenType.BLOCK
try:
command = token.contents.split()[0]
except IndexError:
Variable | Value |
---|---|
nodelist | [<TextNode: '<html lang="en">\n <head>'>] |
parse_until | [] |
self | <django.template.base.Parser object at 0x7f7f426d01d0> |
token | <django.template.base.Token object at 0x7f7f49071ef0> |
/usr/local/lib/python3.5/dist-packages/django/template/base.py
in parse
# Use the raw values here for TokenType.* for a tiny performance boost.
if token.token_type.value == 0: # TokenType.TEXT
self.extend_nodelist(nodelist, TextNode(token.contents), token)
elif token.token_type.value == 1: # TokenType.VAR
if not token.contents:
raise self.error(token, 'Empty variable tag on line %d' % token.lineno)
try:
filter_expression = self.compile_filter(token.contents)...
except TemplateSyntaxError as e:
raise self.error(token, e)
var_node = VariableNode(filter_expression)
self.extend_nodelist(nodelist, var_node, token)
elif token.token_type.value == 2: # TokenType.BLOCK
try:
Variable | Value |
---|---|
nodelist | [<TextNode: '<html lang="en">\n <head>'>] |
parse_until | [] |
self | <django.template.base.Parser object at 0x7f7f426d01d0> |
token | <django.template.base.Token object at 0x7f7f49071ef0> |
/usr/local/lib/python3.5/dist-packages/django/template/base.py
in compile_filter
self.tags.update(lib.tags)
self.filters.update(lib.filters)
def compile_filter(self, token):
"""
Convenient wrapper for FilterExpression
"""
return FilterExpression(token, self)...
def find_filter(self, filter_name):
if filter_name in self.filters:
return self.filters[filter_name]
else:
raise TemplateSyntaxError("Invalid filter: '%s'" % filter_name)
Variable | Value |
---|---|
self | <django.template.base.Parser object at 0x7f7f426d01d0> |
token | 'column | capitalize' |
/usr/local/lib/python3.5/dist-packages/django/template/base.py
in __init__
filter_name = match.group("filter_name")
args = []
constant_arg, var_arg = match.group("constant_arg", "var_arg")
if constant_arg:
args.append((False, Variable(constant_arg).resolve({})))
elif var_arg:
args.append((True, Variable(var_arg)))
filter_func = parser.find_filter(filter_name)...
self.args_check(filter_name, filter_func, args)
filters.append((filter_func, args))
upto = match.end()
if upto != len(token):
raise TemplateSyntaxError("Could not parse the remainder: '%s' "
"from '%s'" % (token[upto:], token))
Variable | Value |
---|---|
args | [] |
constant | None |
constant_arg | None |
filter_name | 'capitalize' |
filters | [] |
match | <_sre.SRE_Match object; span=(6, 19), match=' | capitalize'> |
matches | <callable_iterator object at 0x7f7f426d0f98> |
parser | <django.template.base.Parser object at 0x7f7f426d01d0> |
self | <django.template.base.FilterExpression object at 0x7f7f426d00b8> |
start | 6 |
token | 'column | capitalize' |
upto | 6 |
var | 'column' |
var_arg | None |
var_obj | <Variable: 'column'> |
/usr/local/lib/python3.5/dist-packages/django/template/base.py
in find_filter
"""
return FilterExpression(token, self)
def find_filter(self, filter_name):
if filter_name in self.filters:
return self.filters[filter_name]
else:
raise TemplateSyntaxError("Invalid filter: '%s'" % filter_name)...
# This only matches constant *strings* (things in quotes or marked for
# translation). Numbers are treated as variables for implementation reasons
# (so that they retain their type when passed to filters).
constant_string = r"""
Variable | Value |
---|---|
filter_name | 'capitalize' |
self | <django.template.base.Parser object at 0x7f7f426d01d0> |
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 | '115.28.228.57' |
HTTP_USER_AGENT | 'claudebot' |
PATH_INFO | '/partner' |
QUERY_STRING | '' |
REMOTE_ADDR | '35.153.156.108' |
REMOTE_PORT | '48296' |
REQUEST_METHOD | 'GET' |
REQUEST_SCHEME | 'http' |
REQUEST_URI | '/partner' |
SCRIPT_NAME | '' |
SERVER_NAME | '*.openerp.hk' |
SERVER_PORT | '80' |
SERVER_PROTOCOL | 'HTTP/1.1' |
uwsgi.core | 2 |
uwsgi.node | b'iZ286w70ic2Z' |
uwsgi.version | b'2.0.18' |
wsgi.errors | <_io.TextIOWrapper name=2 mode='w' encoding='UTF-8'> |
wsgi.file_wrapper | '' |
wsgi.input | <uwsgi._Input object at 0x7f7f426c5840> |
wsgi.multiprocess | True |
wsgi.multithread | True |
wsgi.run_once | False |
wsgi.url_scheme | 'http' |
wsgi.version | (1, 0) |
www.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['115.28.228.57', 'cdn.openerp.hk', '127.0.0.1', 'www.odoostart.com', 'odoo.openerp.hk', 'openerp.hk'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | '/root/www' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CRISPY_CLASS_CONVERTERS | {'fileinput': 'fileinput fileUpload form-control', 'passwordinput': '********************', 'textinput': 'textinput textInput form-control'} |
CRISPY_TEMPLATE_PACK | 'bootstrap3' |
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_MAX_AGE': 0, 'ENGINE': 'django.db.backends.mysql', 'HOST': 'localhost', 'NAME': 'openerphk', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '3306', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'root'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
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', '%Y-%m-%d', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%Y', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M', '%m/%d/%y'] |
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_CHARSET | 'utf-8' |
DEFAULT_CONTENT_TYPE | 'text/html' |
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_CHARSET | 'utf-8' |
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 | None |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 0 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
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', 'userApp', 'DjangoUeditor', 'odoo', 'enweb', 'caseApp', 'developApp', 'document', 'user_upload', 'Application', 'Haproxy_app', 'xadmin', 'crispy_forms', 'pure_pagination'] |
INTERNAL_IPS | [] |
LANGUAGES | [('af', 'Afrikaans'), ('ar', 'Arabic'), ('ast', 'Asturian'), ('az', 'Azerbaijani'), ('bg', 'Bulgarian'), ('be', 'Belarusian'), ('bn', 'Bengali'), ('br', 'Breton'), ('bs', 'Bosnian'), ('ca', 'Catalan'), ('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'), ('ia', 'Interlingua'), ('id', 'Indonesian'), ('io', 'Ido'), ('is', 'Icelandic'), ('it', 'Italian'), ('ja', 'Japanese'), ('ka', 'Georgian'), ('kab', 'Kabyle'), ('kk', 'Kazakh'), ('km', 'Khmer'), ('kn', 'Kannada'), ('ko', 'Korean'), ('lb', 'Luxembourgish'), ('lt', 'Lithuanian'), ('lv', 'Latvian'), ('mk', 'Macedonian'), ('ml', 'Malayalam'), ('mn', 'Mongolian'), ('mr', 'Marathi'), ('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'), ('th', 'Thai'), ('tr', 'Turkish'), ('tt', 'Tatar'), ('udm', 'Udmurt'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'fa', 'ur'] |
LANGUAGE_CODE | 'zh-hans' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_DIRS | '/root/www/media' |
MEDIA_ROOT | '/media/' |
MEDIA_URL | '/media/' |
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_DAYS | '********************' |
PREPEND_WWW | False |
ROOT_URLCONF | 'www.urls' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | False |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | False |
SERVER_EMAIL | 'root@localhost' |
SESSION_CACHE_ALIAS | 'default' |
SESSION_COOKIE_AGE | 3600 |
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 | True |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'www.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 | ['/root/www/static'] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/static/' |
STATIC_URL | '/static/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/root/www/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', 'django.template.context_processors.media']}}] |
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 | 'Asia/Shanghai' |
USE_I18N | True |
USE_L10N | True |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | False |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'www.wsgi.application' |
X_FRAME_OPTIONS | 'SAMEORIGIN' |
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.