| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224 | 
							- from Controller import OTAEquipment
 
- from django.views.decorators.csrf import csrf_exempt
 
- from django.views.generic import TemplateView
 
- from django.utils.decorators import method_decorator
 
- from Ansjer import config as api_settings
 
- from Service.ModelService import ModelService
 
- import time,os
 
- from Object.ResponseObject import ResponseObject
 
- from Object.TokenObject import TokenObject
 
- from Ansjer.config import BASE_DIR
 
- def StatisticsData(request):
 
-     print('------request------')
 
-     print(request)
 
-     print('---------------')
 
-     try:
 
-         real_ip = request.META['HTTP_X_FORWARDED_FOR']
 
-         clientIP = real_ip.split(",")[0]
 
-     except:
 
-         try:
 
-             clientIP = request.META['REMOTE_ADDR']
 
-         except Exception as e:
 
-             clientIP = ''
 
-     nowTime = time.strftime('%Y-%m-%d', time.localtime(time.time()))
 
-     print(u'当前用户: %s , 访问时间: %s' % (clientIP, nowTime))
 
-     print(u'~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~')
 
-     for cookKey, cookValue in request.COOKIES.items():
 
-         print("COOKIES:", cookKey, cookValue)
 
-     for sessionKey, sessionValue in request.session.items():
 
-         print("session:", sessionKey, sessionValue)
 
-     print('HTTP_COOKIE', request.META.get('HTTP_COOKIE', 'unknown'))
 
-     print('CSRF_COOKIE', request.META.get('CSRF_COOKIE', 'unknown'))
 
-     print('user', request.user)
 
-     print(u'~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~')
 
-     # print("body:", request.body)
 
-     print('path', request.path)
 
-     print('path_info', request.path_info)
 
-     print('encoding', request.encoding)
 
-     print('resolver_match', request.resolver_match)
 
-     for fileKey, fileValue in request.FILES.items():
 
-         print("FILES:", fileKey, fileValue)
 
-     #print('META', request.META)
 
-     print(u'******************************************************')
 
-     print('DOCUMENT_ROOT', request.META.get('DOCUMENT_ROOT', 'unknown'))
 
-     print('QUERY_STRING: ', request.META.get('QUERY_STRING', 'unknown'))
 
-     print('REMOTE_ADDR', request.META.get('REMOTE_ADDR', 'unknown'))
 
-     print('HTTP_HOST', request.META.get('HTTP_HOST', u'unknown'))
 
-     print('HTTP_REFERER', request.META.get('HTTP_REFERER', 'unknown'))
 
-     print('HTTP_COOKIE', request.META.get('HTTP_COOKIE', 'unknown'))
 
-     print('CSRF_COOKIE', request.META.get('CSRF_COOKIE', 'unknown'))
 
-     print('HTTP_CONNECTION', request.META.get('HTTP_CONNECTION', 'unknown'))
 
-     print('wsgi.errors', request.META.get('wsgi.errors', 'unknown'))
 
-     print('mod_wsgi.application_group', request.META.get('mod_wsgi.application_group', 'unknown'))
 
-     print('mod_wsgi.callable_object', request.META.get('mod_wsgi.callable_object', 'unknown'))
 
-     print('mod_wsgi.listener_host', request.META.get('mod_wsgi.listener_host', 'unknown'))
 
-     print('mod_wsgi.listener_port', request.META.get('mod_wsgi.listener_port', 'unknown'))
 
-     print('mod_wsgi.process_group', request.META.get('mod_wsgi.process_group', 'unknown'))
 
-     print('mod_wsgi.reload_mechanism', request.META.get('mod_wsgi.reload_mechanism', 'unknown'))
 
-     print('mod_wsgi.script_reloading', request.META.get('mod_wsgi.script_reloading', 'unknown'))
 
-     print('mod_wsgi.version', request.META.get('mod_wsgi.version', 'unknown'))
 
-     print('PATH', request.META.get('PATH', 'unknown'))
 
-     print('PATH_INFO', request.META.get('PATH_INFO', 'unknown'))
 
-     print('PATH_TRANSLATED', request.META.get('PATH_TRANSLATED', 'unknown'))
 
-     print('QUERY_STRING', request.META.get('QUERY_STRING', 'unknown'))
 
-     print('QUERY_STRING', request.META.get('REMOTE_ADDR', 'unknown'))
 
-     print('REMOTE_PORT', request.META.get('REMOTE_PORT', 'unknown'))
 
-     print('REQUEST_METHOD', request.META.get('REQUEST_METHOD', 'unknown'))
 
-     print('REQUEST_URI', request.META.get('REQUEST_URI', 'unknown'))
 
-     print('SCRIPT_FILENAME', request.META.get('SCRIPT_FILENAME', 'unknown'))
 
-     print('SCRIPT_NAME', request.META.get('SCRIPT_NAME', 'unknown'))
 
-     print('SERVER_ADDR', request.META.get('SERVER_ADDR', 'unknown'))
 
-     print('SERVER_ADMIN', request.META.get('SERVER_ADMIN', 'unknown'))
 
-     print('SERVER_NAME', request.META.get('SERVER_NAME', 'unknown'))
 
-     print('SERVER_PORT', request.META.get('SERVER_PORT', 'unknown'))
 
-     print('SERVER_PROTOCOL', request.META.get('SERVER_PROTOCOL', 'unknown'))
 
-     print('SERVER_SIGNATURE', request.META.get('SERVER_SIGNATURE', 'unknown'))
 
-     print('SERVER_SOFTWARE', request.META.get('SERVER_SOFTWARE', 'unknown'))
 
-     print('wsgi.input', request.META.get('wsgi.input', 'unknown'))
 
-     print('wsgi.multiprocess', request.META.get('wsgi.multiprocess', 'unknown'))
 
-     print('wsgi.multithread', request.META.get('wsgi.multithread', 'unknown'))
 
-     print('wsgi.run_once', request.META.get('wsgi.run_once', 'unknown'))
 
-     print('wsgi.url_scheme', request.META.get('wsgi.url_scheme', 'unknown'))
 
-     print('wsgi.version', request.META.get('wsgi.version', 'unknown'))
 
-     print('get_host', request.get_host())
 
-     print('get_full_path', request.get_full_path())
 
-     print('build_absolute_uri', request.build_absolute_uri())
 
-     print('is_secure', request.is_secure())
 
-     print('is_ajax', request.is_ajax())
 
-     print(u'******************************************************')
 
-     print('CONTENT_LENGTH: ', request.META.get('CONTENT_LENGTH', 'unknown'))
 
-     print('CONTENT_TYPE', request.META.get('CONTENT_TYPE', 'unknown'))
 
-     print('HTTP_ACCEPT', request.META.get('HTTP_ACCEPT', 'unknown'))
 
-     print('HTTP_ACCEPT_ENCODING', request.META.get('HTTP_ACCEPT_ENCODING', 'unknown'))
 
-     print('REMOTE_HOST', request.META.get('REMOTE_HOST', 'unknown'))
 
-     print('REMOTE_USER', request.META.get('REMOTE_USER', 'unknown'))
 
-     print('REQUEST_METHOD', request.META.get('REQUEST_METHOD', 'unknown'))
 
-     print('SERVER_NAME', request.META.get('SERVER_NAME', 'unknown'))
 
-     print('SERVER_PORT', request.META.get('SERVER_PORT', 'unknown'))
 
-     print('HTTP_USER_AGENT', request.META.get('HTTP_USER_AGENT', 'unknown'))
 
-     print('HTTP_AUTHORIZATION', request.META.get('HTTP_AUTHORIZATION', b'unknown'))
 
- class HelpView(TemplateView):
 
-     '''
 
-     帮助说明,包括版本信息,帮助文件等
 
-     '''
 
-     @method_decorator(csrf_exempt)
 
-     def dispatch(self, *args, **kwargs):
 
-         return super(HelpView, self).dispatch(*args, **kwargs)
 
-     def get(self, request, *args, **kwargs):
 
-         reInfoType = request.GET.get('reInfoType', None)
 
-         token = request.GET.get('token', None)
 
-         return self.getRequestInfo(reInfoType,token)
 
-     def post(self, request, *args, **kwargs):
 
-         reInfoType = request.POST.get('reInfoType', None)
 
-         token = request.POST.get('token', None)
 
-         return self.getRequestInfo(reInfoType,token)
 
-     def getRequestInfo(self, reInfoType,token):
 
-         response = ResponseObject()
 
-         if reInfoType is not None and token is not None:
 
-             tko = TokenObject(token)
 
-             response.lang = tko.lang
 
-             if tko.code == 0:
 
-                 userID = tko.userID
 
-                 own_permission = ModelService.check_perm(userID=userID, permID=30)
 
-                 if own_permission is True:
 
-                     if reInfoType == 'version':
 
-                         return self.readInfo(response)
 
-                     elif reInfoType == 'requirements':
 
-                         return self.requirementsInfo(response)
 
-                     elif reInfoType == 'helpfile':
 
-                         return self.getHelpCHM(response)
 
-                     else:
 
-                         return response.json(444)
 
-                 else:
 
-                     return response.json(404)
 
-             else:
 
-                 return response.json(tko.code)
 
-         else:
 
-             return response.json(800,'reInfoType','reInfoType')
 
-     def readInfo(self,response):
 
-         verfilePath = '/'.join((api_settings.BASE_DIR, 'static/Help/')).replace('\\', '/') + 'version.txt'
 
-         if os.path.isfile(verfilePath):
 
-             file = open(verfilePath, encoding='utf-8')
 
-             versionStr = ''
 
-             for line in file:
 
-                 versionStr += line
 
-             return response.json(0,{'versioninfo':versionStr})
 
-         else:
 
-             return response.json(701)
 
-     def requirementsInfo(self,response):
 
-         requirementsPath = '/'.join((api_settings.BASE_DIR, 'requirements.txt')).replace('\\', '/')
 
-         print(requirementsPath)
 
-         if os.path.isfile(requirementsPath):
 
-             file = open(requirementsPath, encoding='utf-8')
 
-             requirementsStr = ''
 
-             for line in file:
 
-                 requirementsStr += line
 
-             return response.json(0,{'requirementsinfo': requirementsStr})
 
-         else:
 
-             return response.json(701)
 
-     def getHelpCHM(self,response):
 
-         verHelpCHM = '/'.join((api_settings.BASE_DIR, 'static/Help/')).replace('\\', '/') + 'AnsjerHelp.CHM'
 
-         print(verHelpCHM)
 
-         if os.path.isfile(verHelpCHM):
 
-             return OTAEquipment.downloadUrl(fileType='CHM', fileCode='', fileVersion='', fileName=verHelpCHM)
 
-         else:
 
-             return response.json(code=701)
 
- def upload_help_chm(request):
 
-     token = request.POST.get('token', None)
 
-     response = ResponseObject()
 
-     if token is not None:
 
-         tko = TokenObject(token)
 
-         response.lang = tko.lang
 
-         if tko.code == 0:
 
-             userID = tko.userID
 
-             own_permission = ModelService.check_perm(userID=userID, permID=30)
 
-             if own_permission is True:
 
-                 f = request.FILES.get('file', None)
 
-                 path = os.path.join(BASE_DIR, 'static/Help/AnsjerHelp.CHM')
 
-                 try:
 
-                     if os.path.exists(path):
 
-                         os.remove(path)
 
-                     with open(path, 'wb+') as destination:
 
-                         for chunk in f.chunks():
 
-                             destination.write(chunk)
 
-                 except Exception as e:
 
-                     print('error:' + repr(e))
 
-                     return response.json(700,{'details': repr(e)})
 
-                 return response.json(0)
 
-             else:
 
-                 return response.json(404)
 
-         else:
 
-             return response.json(tko.code)
 
-     else:
 
-         return response.json(309)
 
- @csrf_exempt
 
- def errorPath(request,**kwargs):
 
-     response = ResponseObject()
 
-     return response.json(414)
 
 
  |