TrainStation matching query does not exist.
Request Method: | GET |
---|---|
Request URL: | https://www.china-travel-guide.net/trains/D7539/ |
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: | Fri, 29 Mar 2024 07:20:20 +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 0x7f6bc1d7da00>> |
request | <WSGIRequest: GET '/trains/D7539/'> |
/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 0x7f6bc007eca0> |
callback_args | () |
callback_kwargs | {'slug': 'D7539'} |
middleware_method | <function CsrfViewMiddleware.process_view at 0x7f6bc0294700> |
request | <WSGIRequest: GET '/trains/D7539/'> |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7f6bc1d7da00> |
wrapped_callback | <function TrainRouteDetailView at 0x7f6bc007eca0> |
/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: Puning>, <TrainStation: Shenzhen Pingshan>, <TrainStation: Chaoshan>, <TrainStation: Guangzhou East >, <TrainStation: Dongguan>, <TrainStation: Shantou>, <TrainStation: Shanwei>, <TrainStation: Chaoyang>, <TrainStation: Huidong>, <TrainStation: Lufeng>]> |
allstationsdict_sorted | OrderedDict([('汕头', 1), ('潮汕', 2), ('潮阳', 3), ('普宁', 3), ('汕尾', 4), ('陆丰', 4), ('惠东', 5), ('深圳坪山', 5), ('东莞', 6), ('广州东', 7), ('常平', 7)]) |
allstationslist | {'东莞': 6, '常平': 7, '广州东': 7, '惠东': 5, '普宁': 3, '汕头': 1, '汕尾': 4, '深圳坪山': 5, '潮汕': 2, '潮阳': 3, '陆丰': 4} |
allstationslist_sorted | [('汕头', 1), ('潮汕', 2), ('潮阳', 3), ('普宁', 3), ('汕尾', 4), ('陆丰', 4), ('惠东', 5), ('深圳坪山', 5), ('东莞', 6), ('广州东', 7), ('常平', 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: Guangzhou East > |
endtime | '17:35' |
firststation | <TrainStation: Shantou> |
hours | '3' |
item | {'arrivaltime': '17:35', 'costtime': 187, 'day': 1, 'departuretime': '17:37', 'distance': 0, 'isend': 0, 'priceed': '125.0', 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': '190.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 | 14 |
laststationsequenceminusone | 13 |
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 | '07' |
popularroutes | <QuerySet [<TrainRouteRank: shantou - shenzhen>, <TrainRouteRank: shantou - guangzhou>, <TrainRouteRank: shantou - chaoshan>]> |
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/D7539/'> |
seq | 7 |
slug | 'D7539' |
starttime | '14:28' |
station | '常平' |
supportedlanguages | ['en', 'fr', 'de'] |
totaltime | datetime.timedelta(seconds=11220) |
totaltime_string | '3 hours 07 minutes' |
totaltimes | '3:07:00' |
tr | <StoredTrainRoute: D7539> |
train | {'msg': 'ok', 'result': {'date': '2019-11-11', 'endstation': '广州东', 'list': [{'arrivaltime': '----', 'costtime': 0, 'day': 1, 'departuretime': '14:28', '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': '14:51', 'costtime': 23, 'day': 1, 'departuretime': '14:56', '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': 7}, {'arrivaltime': '15:08', 'costtime': 61, 'day': 1, 'departuretime': '15:10', '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': 3, 'station': '潮阳', 'stoptime': 2}, {'arrivaltime': '15:19', 'costtime': 51, 'day': 1, 'departuretime': '15:21', 'distance': 0, 'isend': 0, 'priceed': '19.0', 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': '29.0', 'priceyw1': None, 'priceyw2': None, 'priceyw3': None, 'sequenceno': 3, 'station': '普宁', 'stoptime': 2}, {'arrivaltime': '15:54', 'costtime': 88, 'day': 1, 'departuretime': '15:56', 'distance': 0, 'isend': 0, 'priceed': '52.0', 'pricegr1': None, 'pricegr2': None, 'pricerw1': None, 'pricerw2': None, 'pricesw': None, 'pricetd': None, 'priceyd': '83.0', 'priceyw1': None, 'priceyw2': None, 'priceyw3': None, 'sequenceno': 4, 'station': '汕尾', 'stoptime': 2}, {'arrivaltime': '16:04', 'costt… <trimmed 11407 bytes string> |
trainno | <AllTrains: D7539> |
/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 0x7f6bbf75bc70> |
/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.91.43.22' |
HTTP_X_FORWARDED_PORT | '443' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REQUEST_ID | '33f5b720-09fc-4b0b-b85d-c6d9f9c115b3' |
HTTP_X_REQUEST_START | '1711696820398' |
PATH_INFO | '/trains/D7539/' |
QUERY_STRING | '' |
RAW_URI | '/trains/D7539/' |
REMOTE_ADDR | '10.1.81.49' |
REMOTE_PORT | '10465' |
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=10, family=AddressFamily.AF_INET, type=SocketKind.SOCK_STREAM, proto=0, laddr=('172.19.37.82', 22557), raddr=('10.1.81.49', 10465)> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7f6bbf956f40> |
wsgi.file_wrapper | <class 'gunicorn.http.wsgi.FileWrapper'> |
wsgi.input | <gunicorn.http.body.Body object at 0x7f6bc0096430> |
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.