| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224 | from Controller import OTAEquipmentfrom django.views.decorators.csrf import csrf_exemptfrom django.views.generic import TemplateViewfrom django.utils.decorators import method_decoratorfrom Ansjer import config as api_settingsfrom Service.ModelService import ModelServiceimport time,osfrom Object.ResponseObject import ResponseObjectfrom Object.TokenObject import TokenObjectfrom Ansjer.config import BASE_DIRdef 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_exemptdef errorPath(request,**kwargs):    response = ResponseObject()    return response.json(414)
 |