TrainStation matching query does not exist.
Request Method: | GET |
---|---|
Request URL: | https://www.china-travel-guide.net/trains/D3632/ |
Django Version: | 3.2.19 |
Exception Type: | DoesNotExist |
Exception Value: | TrainStation matching query does not exist. |
Exception Location: | /app/.heroku/python/lib/python3.9/site-packages/django/db/models/query.py, line 435, in get |
Python Executable: | /app/.heroku/python/bin/python |
Python Version: | 3.9.16 |
Python Path: | ['/app/.heroku/python/bin', '/app', '/app/.heroku/python/lib/python39.zip', '/app/.heroku/python/lib/python3.9', '/app/.heroku/python/lib/python3.9/lib-dynload', '/app/.heroku/python/lib/python3.9/site-packages', '/app/.heroku/python/lib/python3.9/site-packages/odf', '/app/.heroku/python/lib/python3.9/site-packages/odf', '/app/.heroku/python/lib/python3.9/site-packages/odf', '/app/.heroku/python/lib/python3.9/site-packages/odf', '/app/.heroku/python/lib/python3.9/site-packages/odf', '/app/.heroku/python/lib/python3.9/site-packages/odf', '/app/.heroku/python/lib/python3.9/site-packages/odf'] |
Server time: | Thu, 28 Mar 2024 19:51:55 +0000 |
/app/.heroku/python/lib/python3.9/site-packages/django/core/handlers/exception.py
, line 47, in inner
response = await sync_to_async(response_for_exception, thread_sensitive=False)(request, exc)
return response
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 | DoesNotExist('TrainStation matching query does not exist.') |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7f6bc218c7c0>> |
request | <WSGIRequest: GET '/trains/D3632/'> |
/app/.heroku/python/lib/python3.9/site-packages/django/core/handlers/base.py
, line 181, 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 asyncio.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 TrainRouteDetailView at 0x7f6bc00a2700> |
callback_args | () |
callback_kwargs | {'slug': 'D3632'} |
middleware_method | <function CsrfViewMiddleware.process_view at 0x7f6bc0291040> |
request | <WSGIRequest: GET '/trains/D3632/'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f6bc218c7c0> |
wrapped_callback | <function TrainRouteDetailView at 0x7f6bc00a2700> |
/app/maincontent/views.py
, line 396, in TrainRouteDetailView
allstationslist_sorted = sorted(allstationslist.items(), key=lambda x: x[1])
allstationsdict_sorted = collections.OrderedDict(allstationslist_sorted)
allstationobjects = TrainStation.objects.filter(station_chinese__in=allstationsdict_sorted.keys())
# Find max and min coordinates to determine map centerpoint
firststation = TrainStation.objects.get(station_chinese=allstationslist_sorted[0][0])
laststation = TrainStation.objects.get(…
station_chinese=allstationslist_sorted[len(allstationslist_sorted) - 1][0])
stationlongs = []
stationlats = []
for station in allstationobjects:
try:
Variable | Value |
---|---|
FMT | '%H:%M' |
allstationobjects | <QuerySet [<TrainStation: Nanning East>, <TrainStation: Guangzhou South >, <TrainStation: Foshan West>, <TrainStation: Yunfu East>, <TrainStation: Zhaoqing East>, <TrainStation: Wuzhou South>, <TrainStation: Tengxian>, <TrainStation: Pingnan South>, <TrainStation: Guigang >]> |
allstationsdict_sorted | OrderedDict([('广州南', 1), ('佛山西', 2), ('肇庆东', 2), ('云浮东', 3), ('梧州南', 3), ('藤县', 4), ('平南南', 5), ('贵港', 5), ('南宁东', 6), ('宾阳', 7)]) |
allstationslist | {'云浮东': 3, '佛山西': 2, '南宁东': 6, '宾阳': 7, '平南南': 5, '广州南': 1, '梧州南': 3, '肇庆东': 2, '藤县': 4, '贵港': 5} |
allstationslist_sorted | [('广州南', 1), ('佛山西', 2), ('肇庆东', 2), ('云浮东', 3), ('梧州南', 3), ('藤县', 4), ('平南南', 5), ('贵港', 5), ('南宁东', 6), ('宾阳', 7)] |
arrivalcities | ['Aba Prefecture', 'Ali', 'Altay Region', 'Anshan', 'Anshun', 'Anyang', 'Baoding', 'Baoji', 'Baoshan', 'Baotou', 'Beihai', 'Beijing', "Bo'ao", 'Bozhou', 'Chamdo', 'Changchun', 'Changde', 'Changsha', 'Changshu', 'Changzhou', 'Chengde', 'Chengdu', 'Chongqing', 'Cixi', 'Dali', 'Dalian', 'Dandong', 'Daqing', 'Datong', 'Dehong', 'Dengzhou', 'Dongguan', 'Dujiangyan', 'Dunhuang', 'Emei Shan', 'Enshi', 'Foshan', 'Fushun', 'Fuyang', 'Fuzhou', 'Garze Prefecture', 'Golmud', 'Guangyuan', 'Guangzhou', 'Guilin', 'Guiyang', 'Haikou', 'Handan', 'Hangzhou', 'Harbin', 'Hefei', 'Hohhot', 'Honghe', 'Hong Kong', 'Hotan', "Huai'an", 'Huaibei', 'Huainan', 'Huangshan', 'Huangshi', 'Hua Shan', 'Huizhou', 'Jiangmen', 'Jiangyin', 'Jiayuguan', 'Jilin City', 'Jinan', 'Jingdezhen', 'Jiuhua Shan', 'Jiuzhaigou-Huanglong', 'Kaifeng', 'Kanas Lake', 'Kangding', 'Kashgar', 'Kunming', 'Lanzhou', 'Leshan', 'Lhasa', 'Lijiang', 'Linyi', 'Liuzhou', "Lu'an", 'Luoyang', 'Lu Shan', "Ma'anshan", 'Macau', 'Mianyang', 'Mogan Shan', 'Nagchu', 'Nanchang', 'Nanchong', 'Nanjing', 'Nanning', 'Nantong', 'Nanxun', 'Nanyang', 'Ningbo', 'Nyingtri', 'Panjin', 'Pingyao', 'Pizhou', 'Putian', 'Putuo Shan', 'Qingdao', 'Qinhuangdao', 'Qiqihar', 'Quanzhou', 'Qujing', 'Sanya', 'Shanghai', 'Shangri-La', 'Shantou', 'Shaoxing', 'Shaxi', 'Shennongjia', 'Shenyang', 'Shenzhen', 'Shigatse', 'Shijiazhuang', 'Shunde', 'Songpan', 'Suqian', 'Suzhou', 'Suzhou (Anhui)', "Tai'an", 'Taipei', 'Tai Shan', 'Taiyuan', 'Taizhou', 'Tangshan', 'Tengzhou', 'Three Gorges', 'Tianjin', 'Tongli', 'Tongren', 'Turpan', 'Urumqi', 'Weifang', 'Wenling', 'Wenshanzhou', 'Wenzhou', 'Wudang Shan', 'Wuhan', 'Wuxi', 'Wuyi Shan', 'Wuzhen', 'Xiahe', 'Xiamen', "Xi'an", 'Xiangtan', 'Xichang', 'Xining', 'Xishuangbanna', 'Xitang', 'Xuzhou', "Ya'an", "Yan'an", 'Yancheng', 'Yangshuo', 'Yangzhou', 'Yantai', 'Yibin', 'Yichang', 'Yinchuan', 'Yingkou', 'Yiwu', 'Yulin', 'Yuxi', 'Zhangjiajie', 'Zhangjiakou', 'Zhanjiang', 'Zhaoqing', 'Zhengzhou', 'Zhenjiang', 'Zhongshan', 'Zhouzhuang', 'Zhuhai', 'Zibo', 'Zigong'] |
articles | <QuerySet [<GenericArticle: Chinese Food - Much More Than Fried Rice>, <GenericArticle: New High-Speed Trains From Hong Kong to Chongqing to Start on 10th July>, <GenericArticle: Most common scams in China and how to avoid them>, <GenericArticle: Ultimate China Train Guide>, <GenericArticle: How To Set Up Alipay As a Foreigner>, <GenericArticle: 101 Things to Know Before Visiting China>, <GenericArticle: Best Beaches of China>]> |
cities | <QuerySet [<City: Aba Prefecture>, <City: Ali>, <City: Altay Region>, <City: Anshan>, <City: Anshun>, <City: Anyang>, <City: Baoding>, <City: Baoji>, <City: Baoshan>, <City: Baotou>, <City: Beihai>, <City: Beijing>, <City: Bo'ao>, <City: Bozhou>, <City: Chamdo>, <City: Changchun>, <City: Changde>, <City: Changsha>, <City: Changshu>, <City: Changzhou>, '...(remaining elements truncated)...']> |
city | <City: Zigong> |
departurecities | ['Aba Prefecture', 'Ali', 'Altay Region', 'Anshan', 'Anshun', 'Anyang', 'Baoding', 'Baoji', 'Baoshan', 'Baotou', 'Beihai', 'Beijing', "Bo'ao", 'Bozhou', 'Chamdo', 'Changchun', 'Changde', 'Changsha', 'Changshu', 'Changzhou', 'Chengde', 'Chengdu', 'Chongqing', 'Cixi', 'Dali', 'Dalian', 'Dandong', 'Daqing', 'Datong', 'Dehong', 'Dengzhou', 'Dongguan', 'Dujiangyan', 'Dunhuang', 'Emei Shan', 'Enshi', 'Foshan', 'Fushun', 'Fuyang', 'Fuzhou', 'Garze Prefecture', 'Golmud', 'Guangyuan', 'Guangzhou', 'Guilin', 'Guiyang', 'Haikou', 'Handan', 'Hangzhou', 'Harbin', 'Hefei', 'Hohhot', 'Honghe', 'Hong Kong', 'Hotan', "Huai'an", 'Huaibei', 'Huainan', 'Huangshan', 'Huangshi', 'Hua Shan', 'Huizhou', 'Jiangmen', 'Jiangyin', 'Jiayuguan', 'Jilin City', 'Jinan', 'Jingdezhen', 'Jiuhua Shan', 'Jiuzhaigou-Huanglong', 'Kaifeng', 'Kanas Lake', 'Kangding', 'Kashgar', 'Kunming', 'Lanzhou', 'Leshan', 'Lhasa', 'Lijiang', 'Linyi', 'Liuzhou', "Lu'an", 'Luoyang', 'Lu Shan', "Ma'anshan", 'Macau', 'Mianyang', 'Mogan Shan', 'Nagchu', 'Nanchang', 'Nanchong', 'Nanjing', 'Nanning', 'Nantong', 'Nanxun', 'Nanyang', 'Ningbo', 'Nyingtri', 'Panjin', 'Pingyao', 'Pizhou', 'Putian', 'Putuo Shan', 'Qingdao', 'Qinhuangdao', 'Qiqihar', 'Quanzhou', 'Qujing', 'Sanya', 'Shanghai', 'Shangri-La', 'Shantou', 'Shaoxing', 'Shaxi', 'Shennongjia', 'Shenyang', 'Shenzhen', 'Shigatse', 'Shijiazhuang', 'Shunde', 'Songpan', 'Suqian', 'Suzhou', 'Suzhou (Anhui)', "Tai'an", 'Taipei', 'Tai Shan', 'Taiyuan', 'Taizhou', 'Tangshan', 'Tengzhou', 'Three Gorges', 'Tianjin', 'Tongli', 'Tongren', 'Turpan', 'Urumqi', 'Weifang', 'Wenling', 'Wenshanzhou', 'Wenzhou', 'Wudang Shan', 'Wuhan', 'Wuxi', 'Wuyi Shan', 'Wuzhen', 'Xiahe', 'Xiamen', "Xi'an", 'Xiangtan', 'Xichang', 'Xining', 'Xishuangbanna', 'Xitang', 'Xuzhou', "Ya'an", "Yan'an", 'Yancheng', 'Yangshuo', 'Yangzhou', 'Yantai', 'Yibin', 'Yichang', 'Yinchuan', 'Yingkou', 'Yiwu', 'Yulin', 'Yuxi', 'Zhangjiajie', 'Zhangjiakou', 'Zhanjiang', 'Zhaoqing', 'Zhengzhou', 'Zhenjiang', 'Zhongshan', 'Zhouzhuang', 'Zhuhai', 'Zibo', 'Zigong'] |
endcitystation | <TrainStation: Nanning East> |
endtime | '20:55' |
firststation | <TrainStation: Guangzhou South > |
hours | '20' |
item | {'arrivaltime': '20:55', 'costtime': 4460, 'day': 4, 'departuretime': '20:57', 'distance': 0, 'isend': 0, 'priceed': '144.5', 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': '231.0', 'priceyw1': None, 'priceyw2': None, 'priceyw3': None, 'sequenceno': 7, 'station': '宾阳', 'stoptime': 2} |
keys | {'arrivetime': 'Arrive Time', 'booktickets': 'Book Tickets', 'chinatrainfaq': 'China Train FAQ', 'departtime': 'Depart Time', 'endstation': 'End Station', 'endtime': 'End Time', 'from': 'From:', 'go': 'Search', 'intermediatestations': 'Intermediate Stations', 'latestsearches': 'Latest Searches', 'nexttrainsinseqence': 'Next Trains In Sequence', 'question1answer': 'Second class is the standard seating which normally takes ' 'up 80%+ of the train. Seats are configured in a 3 + 2 ' 'arrangement and are spacious compared to plane seats. ' 'First class seats are wider, positioned in a 2+2 ' 'arrangement, have slightly more legroom and a foldout ' 'foot stand. Business class is the top class (Yes, it’s ' 'opposite to airplanes), and is typically a 2+1 ' 'arrangement. It’s much like first class on a plane, with ' 'full lie-flat electric seats and (some) complimentary ' 'food.', 'question1title': 'What’s the different between Business, First and Second ' 'class?', 'question2answer': 'G trains are the fastest, travelling at 300 km/h on all ' 'routes, and 350 km/h on select routes including Beijing ' 'to Shanghai. D trains are also quite fast, travelling at ' '200-250 km/h. Other trains travel between 100-140 km/h ' 'and aren’t considered high-speed.', 'question2title': 'How fast are the trains?', 'question3answer': 'No, only single direction train tickets can be purchased. ' 'Although some services will allow you to purchase return ' 'tickets, this is really just two one-way fares and there ' 'is no discount.', 'question3title': 'Is there a discount for return tickets?', 'question4answer': 'You can purchase China Train Tickets up to 30 days in ' 'advance (previously it was 60 days). Occasionally, China ' 'Rail will do a major timetable adjustment which usually ' 'involves adding new trains and routes, and the forward ' 'booking window might by as short as 10 days.', 'question4title': 'How far in advance can I purchase China Train Tickets?', 'searchtrains': 'Search Trains', 'startstation': 'Start Station', 'starttime': 'Start Time', 'stationname': 'Station Name', 'stationno': 'Station No.', 'stoptime': 'Stop Time', 'to': 'to', 'to2': 'To:', 'topchinatrainnos': 'Top China Train Numbers', 'topchinatrainroutes': 'Top China Train Routes', 'trainnumber': 'Train Number', 'traintype': 'Train Type'} |
languageslug | 'en' |
laststationsequence | 10 |
laststationsequenceminusone | 9 |
latestsearches | <QuerySet [<TrainSearchHistory: kunming dali>, <TrainSearchHistory: nanning guilin>, <TrainSearchHistory: dalian guiyang>, <TrainSearchHistory: lanzhou chengdu>, <TrainSearchHistory: shenzhen guangzhou>, <TrainSearchHistory: zhuhai zhuhai>, <TrainSearchHistory: dalian jinzhou>, <TrainSearchHistory: changsha zhengzhou>, <TrainSearchHistory: xining geermu>, <TrainSearchHistory: nanning liuzhou>, <TrainSearchHistory: tianjin shanhaiguan>, <TrainSearchHistory: datong chongqing>]> |
minutes | '55' |
popularroutes | <QuerySet []> |
popularroutesall | <QuerySet [<TrainRouteRank: shanghai - beijing>, <TrainRouteRank: hangzhou - shanghai>, <TrainRouteRank: shanghai - hangzhou>, <TrainRouteRank: beijing - shanghai>, <TrainRouteRank: shanghai - suzhou>, <TrainRouteRank: suzhou - shanghai>, <TrainRouteRank: guangzhou - shenzhen>, <TrainRouteRank: shenzhen - guangzhou>, <TrainRouteRank: nanjing - shanghai>, <TrainRouteRank: shanghai - nanjing>, <TrainRouteRank: guangzhou - xianggangxijiulong>, <TrainRouteRank: xianggangxijiulong - guangzhou>, <TrainRouteRank: tianjin - beijing>, <TrainRouteRank: beijing - tianjin>, <TrainRouteRank: shanghai - wuxi>, <TrainRouteRank: beijing - xian>, <TrainRouteRank: ningbo - shanghai>, <TrainRouteRank: wuxi - shanghai>, <TrainRouteRank: shanghai - ningbo>, <TrainRouteRank: yiwu - shanghai>, '...(remaining elements truncated)...']> |
popularroutesto | <QuerySet []> |
populartrainnumbers | <QuerySet [<TrainNumber: G99>, <TrainNumber: G100>, <TrainNumber: G6386>, <TrainNumber: G5624>, <TrainNumber: D8791>, <TrainNumber: D7751>, <TrainNumber: D7325>, <TrainNumber: D5126>, <TrainNumber: C6511>, <TrainNumber: C2641>, <TrainNumber: C2623>, <TrainNumber: C2592>, <TrainNumber: D1851>, <TrainNumber: G1810>, <TrainNumber: C7699>, <TrainNumber: D374>, <TrainNumber: G8046>, <TrainNumber: G8560>, <TrainNumber: G6746>, <TrainNumber: G1870>, '...(remaining elements truncated)...']> |
request | <WSGIRequest: GET '/trains/D3632/'> |
seq | 7 |
slug | 'D3632' |
starttime | '00:00' |
station | '宾阳' |
supportedlanguages | ['en', 'fr', 'de'] |
totaltime | datetime.timedelta(seconds=75300) |
totaltime_string | '20 hours 55 minutes' |
totaltimes | '20:55:00' |
tr | <StoredTrainRoute: D3632> |
train | {'msg': 'ok', 'result': {'date': '2019-11-12', 'endstation': '南宁东', 'list': [{'arrivaltime': '18:35', 'costtime': 0, 'day': 1, 'departuretime': '24:00', 'distance': 0, 'isend': 0, 'priceed': None, 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': None, 'priceyw1': None, 'priceyw2': None, 'priceyw3': None, 'sequenceno': 1, 'station': '广州南', 'stoptime': 0}, {'arrivaltime': '17:56', 'costtime': 1401, 'day': 2, 'departuretime': '17:58', 'distance': 0, 'isend': 0, 'priceed': '10.0', 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': '16.0', 'priceyw1': None, 'priceyw2': None, 'priceyw3': None, 'sequenceno': 2, 'station': '佛山西', 'stoptime': 2}, {'arrivaltime': '24:00', 'costtime': 36, 'day': 2, 'departuretime': '24:00', 'distance': 0, 'isend': 0, 'priceed': None, 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': None, 'priceyw1': None, 'priceyw2': None, 'priceyw3': None, 'sequenceno': 2, 'station': '肇庆东', 'stoptime': 2}, {'arrivaltime': '18:39', 'costtime': 1444, 'day': 2, 'departuretime': '18:41', 'distance': 0, 'isend': 0, 'priceed': '42.5', 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': '68.0', 'priceyw1': None, 'priceyw2': None, 'priceyw3': None, 'sequenceno': 3, 'station': '云浮东', 'stoptime': 2}, {'arrivaltime': '24:00', 'costtime': 1527, 'day': 2, 'departuretime': '24:00', 'distance': 0, 'isend': 0, 'priceed': '76.0', 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': '121.0', 'priceyw1': None, 'priceyw2': None, 'priceyw3': None, 'sequenceno': 3, 'station': '梧州南', 'stoptime': 5}, {'arrivaltime': '24:00', … <trimmed 8227 bytes string> |
trainno | <AllTrains: D3632> |
/app/.heroku/python/lib/python3.9/site-packages/django/db/models/manager.py
, line 85, in manager_method
def check(self, **kwargs):
return []
@classmethod
def _get_queryset_methods(cls, queryset_class):
def create_method(name, method):
def manager_method(self, *args, **kwargs):
return getattr(self.get_queryset(), name)(*args, **kwargs)…
manager_method.__name__ = method.__name__
manager_method.__doc__ = method.__doc__
return manager_method
new_methods = {}
for name, method in inspect.getmembers(queryset_class, predicate=inspect.isfunction):
Variable | Value |
---|---|
args | () |
kwargs | {'station_chinese': '宾阳'} |
name | 'get' |
self | <django.db.models.manager.Manager object at 0x7f6bbf790280> |
/app/.heroku/python/lib/python3.9/site-packages/django/db/models/query.py
, line 435, in get
if not clone.query.select_for_update or connections[clone.db].features.supports_select_for_update_with_limit:
limit = MAX_GET_RESULTS
clone.query.set_limits(high=limit)
num = len(clone)
if num == 1:
return clone._result_cache[0]
if not num:
raise self.model.DoesNotExist(…
"%s matching query does not exist." %
self.model._meta.object_name
)
raise self.model.MultipleObjectsReturned(
'get() returned more than one %s -- it returned %s!' % (
self.model._meta.object_name,
Variable | Value |
---|---|
args | () |
clone | <QuerySet []> |
kwargs | {'station_chinese': '宾阳'} |
limit | 21 |
num | 0 |
self | <QuerySet [<TrainStation: Dezhou East>, <TrainStation: Handan East>, <TrainStation: Nanning East>, <TrainStation: Xuchang East>, <TrainStation: Pingxiang North>, <TrainStation: Shenyang South>, <TrainStation: Panzhou>, <TrainStation: Hunchun>, <TrainStation: Liangping South>, <TrainStation: Xinhui>, <TrainStation: Huashan South>, <TrainStation: Dongfanghong>, <TrainStation: Akto>, <TrainStation: Maoming West>, <TrainStation: Tuha>, <TrainStation: Shenshu>, <TrainStation: Shenzhou>, <TrainStation: Meizhou West>, <TrainStation: Yundonghai>, <TrainStation: Quanjiao>, '...(remaining elements truncated)...']> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'close' |
HTTP_CONNECT_TIME | '0' |
HTTP_HOST | 'www.china-travel-guide.net' |
HTTP_TOTAL_ROUTE_TIME | '0' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_VIA | '1.1 vegur' |
HTTP_X_FORWARDED_FOR | '3.89.56.228' |
HTTP_X_FORWARDED_PORT | '443' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REQUEST_ID | 'f5a40592-c930-4b91-9c16-dca8c2fd2bdc' |
HTTP_X_REQUEST_START | '1711655515068' |
PATH_INFO | '/trains/D3632/' |
QUERY_STRING | '' |
RAW_URI | '/trains/D3632/' |
REMOTE_ADDR | '10.1.4.238' |
REMOTE_PORT | '19783' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | '0.0.0.0' |
SERVER_PORT | '22557' |
SERVER_PROTOCOL | 'HTTP/1.1' |
SERVER_SOFTWARE | 'gunicorn/19.8.1' |
gunicorn.socket | <socket.socket fd=11, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('172.19.37.82', 22557), raddr=('10.1.4.238', 19783)> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f6bbf750340> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7f6bbe98e460> |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
travelsite.settings
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ALLOWED_HOSTS | ['www.china-travel-guide.net'] |
APPEND_SLASH | True |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
AWS_ACCESS_KEY_ID | '********************' |
AWS_S3_CUSTOM_DOMAIN | 's3.us-east-2.amazonaws.com/travelguidechi' |
AWS_S3_OBJECT_PARAMETERS | {'CacheControl': 'max-age=94608000', 'Expires': 'Thu, 31 Dec 2099 20:00:00 GMT'} |
AWS_S3_REGION_NAME | 'us-east-2' |
AWS_SECRET_ACCESS_KEY | '********************' |
AWS_STORAGE_BUCKET_NAME | 'travelguidechi' |
BASE_DIR | '/app' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', 'LOCATION': '128.199.222.144:11211'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CELERY_BROKER_URL | 'amqp://localhost' |
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 | True |
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.postgresql_psycopg2', 'HOST': 'ec2-44-194-4-127.compute-1.amazonaws.com', 'NAME': 'd4pt2prg4ttlen', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': 5432, 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIGRATE': True, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'jhmavnkazuksei'}} |
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 | 'storages.backends.s3boto3.S3Boto3Storage' |
DEFAULT_FROM_EMAIL | 'webmaster@localhost' |
DEFAULT_HASHING_ALGORITHM | 'sha256' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EASY_MAPS_GOOGLE_MAPS_API_KEY | '********************' |
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 |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
IGNORABLE_404_URLS | [] |
IMPORT_EXPORT_USE_TRANSACTIONS | True |
INSTALLED_APPS | ('django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'maincontent', 'django.contrib.humanize', 'django.contrib.sitemaps', 'django.contrib.sites', 's3direct', 'storages', 'import_export', 'robots', 'haversine', 'debug_toolbar') |
INTERNAL_IPS | ['180.150.112.207'] |
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'), ('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'), ('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'), ('uk', 'Ukrainian'), ('ur', 'Urdu'), ('uz', 'Uzbek'), ('vi', 'Vietnamese'), ('zh-hans', 'Simplified Chinese'), ('zh-hant', 'Traditional Chinese')] |
LANGUAGES_BIDI | ['he', 'ar', 'ar-dz', 'fa', '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 | {'disable_existing_loggers': False, 'handlers': {'console': {'class': 'logging.StreamHandler'}}, 'root': {'handlers': ['console'], 'level': 'ERROR'}, 'version': 1} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '' |
MEDIA_URL | '/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ('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', 'django.middleware.security.SecurityMiddleware') |
MIGRATION_MODULES | {} |
MONTH_DAY_FORMAT | 'F j' |
NUMBER_GROUPING | 0 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PREPEND_WWW | False |
PROJECT_ROOT | '/app/travelsite' |
ROOT_URLCONF | 'travelsite.urls' |
S3DIRECT_DESTINATIONS | {'ctgcitys3': {'allowed': ['image/jpeg', 'image/png', 'video/mp4'], 'cache_control': 'max-age=2592000', 'content_disposition': 'attachment', 'content_length_range': (5000, 20000000), 'key': '********************', 'server_side_encryption': 'AES256'}, 'ctgs3': {'allowed': ['image/jpeg', 'image/png', 'video/mp4'], 'cache_control': 'max-age=2592000', 'content_disposition': 'attachment', 'content_length_range': (5000, 20000000), 'key': '********************', 'server_side_encryption': 'AES256'}, 'genericarticle': {'allowed': ['image/jpeg', 'image/png', 'video/mp4'], 'cache_control': 'max-age=2592000', 'content_disposition': 'attachment', 'content_length_range': (5000, 20000000), 'key': '********************', 'server_side_encryption': 'AES256'}} |
S3DIRECT_REGION | 'us-east-2' |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | True |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | ('HTTP_X_FORWARDED_PROTO', 'https') |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_REFERRER_POLICY | 'same-origin' |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | True |
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 | True |
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 | 'travelsite.settings' |
SHORT_DATETIME_FORMAT | 'm/d/Y P' |
SHORT_DATE_FORMAT | 'm/d/Y' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
SITE_ID | 1 |
STATICFILES_DIRS | ('/app/travelsite/static',) |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'storages.backends.s3boto3.S3Boto3Storage' |
STATIC_ROOT | '/app/travelsite/staticfiles' |
STATIC_URL | 'https://s3.us-east-2.amazonaws.com/travelguidechi/' |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [], '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 | 'travelsite.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.