middleware.py 3.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. from django.utils.deprecation import MiddlewareMixin
  4. from Ansjer import local_settings as api_settings
  5. from Ansjer.config import SERVER_TYPE
  6. from Object.ResponseObject import ResponseObject
  7. from Service.MiscellService import MiscellService
  8. import django.db
  9. # 设置mysql超时
  10. class StatisticsUrlMiddleware(MiddlewareMixin):
  11. def _https_statistics_to_reverse(self, request):
  12. '''
  13. :param request:
  14. :return:
  15. '''
  16. # 限制同时下载量
  17. path = request.path
  18. index = path.find('/OTA/downloads')
  19. if index != -1:
  20. addsCount = len(api_settings.ADDR_URL)
  21. if addsCount > 1000:
  22. return -1
  23. else:
  24. adds = request.META.get('REMOTE_ADDR', None)
  25. api_settings.ADDR_URL.append(adds)
  26. # MiscellService.add_ota_download_log(request=request)
  27. return 0
  28. def _https_statistics_to_close(self, request):
  29. '''
  30. :param request:
  31. :return:
  32. '''
  33. addsCount = len(api_settings.ADDR_URL)
  34. if addsCount > 0:
  35. api_settings.ADDR_URL.pop(0)
  36. def process_request(self, request):
  37. '''
  38. :function description
  39. Request预处理函数: process_request(self, request)
  40. :param request:
  41. :return: 应当返回 None 或 HttpResponse 对象
  42. 如果返回 None ,Django 将继续处理这个 request,执行后续的中间件,
  43. 然后调用相应的 view。
  44. 如果返回 HttpResponse 对象,Django 将不再执行任何其它的中间件
  45. (无视其种类)以及相应的view。 Django将立即返回该 HttpResponse。
  46. '''
  47. if request.path != '/favicon.ico':
  48. print('process_request', request)
  49. result = self._https_statistics_to_reverse(request)
  50. if result == -1:
  51. response = ResponseObject()
  52. return response.json(910)
  53. return None
  54. def process_view(self, request, callback, callback_args, callback_kwargs):
  55. if request.path != '/favicon.ico':
  56. print('process_view', request)
  57. return None
  58. def process_response(self, request, response):
  59. '''
  60. :function description
  61. Response后处理函数: process_response(self, request, response)
  62. 这个方法的调用时机在 Django 执行 view 函数并生成 response 之后。
  63. :param request: request 对象
  64. :param response: 从 view 中返回的 response 对象
  65. :return: 必须返回 HttpResponse 对象. 这个 response 对象可以是传入函数的那一个原始对象(通常已被修改),也可以是全新生成的。
  66. 该处理器能修改 response 的内容;一个常见的用途是内容压缩,如 gzip 所请求的 HTML 页面。
  67. '''
  68. self._https_statistics_to_close(request)
  69. ########记录访问日志
  70. # MiscellService.DynamoDB_add_access_log(request=request, status_code=response.status_code)
  71. if request.path !='/favicon.ico':
  72. print('process_response', request, response)
  73. try:
  74. pass
  75. # mysql
  76. if SERVER_TYPE!="Ansjer.formal_settings":
  77. # print('添加日志')
  78. MiscellService.add_access_log(request=request, status_code=response.status_code)
  79. # else:
  80. # print('不添加日志')
  81. # mongodb版
  82. # MiscellService.access_log(request=request, response=response, type=0)
  83. except Exception as e:
  84. print(repr(e))
  85. django.db.close_old_connections()
  86. return response