2016-07-22 5 views
1

Mein REST-APIs:django: maßgeschneiderter Dekorateur laufen, bevor django-Rest-Rahmen-Authentifizierung Klasse

class FileView(APIView): 
    parser_classes = (MultiPartParser,) 
    authentication_classes = (BasicAuthentication,) 
    permission_classes = (IsAuthenticated,) 

@method_decorator(csrf_exempt) 
@method_decorator(operation_logger) 
def dispatch(self, request, *args, **kwargs): 
    return super(FileView, self).dispatch(request, *args, **kwargs) 

def post(self, request): 
    print "xxxxpost" 

Die maßgeschneiderte Dekorateur:

def operation_logger(view_func): 
    @wraps(view_func) 
    def wrapper(request, *args, **kwargs): 
     print "xxxx" 
     comments = [] 
     psfile = None 
     op = None 
     remote_addr = request.META.get('REMOTE_ADDR') 
     if request.user: 
      user = request.user 
      print request.user.username 
     else: 
      print "request.user is None" 

     return view_func(request, *args, **kwargs) 

    return wrapper 

Es scheint, dass mein Dekorateur ausgeführt wird, bevor die Authentifizierung abgeschlossen. Wie man es repariert? Dank

UPDATE habe ich meine Middleware-Liste unten. Aber ich bin mir nicht sicher, ob es verwandt ist, weil ich eine neue App für APIs erstellt habe, die djangorestframework verwendet.

MIDDLEWARE_CLASSES = (
    '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', 
    'lib.middleware.SessionTimeout', 
    'lib.middleware.ForceTemporaryPasswordChange' 
) 
+0

Was ist Ihre Middleware-Bestellung? http://simpleisbetterthancomplex.com/tutorial/2016/07/18/how-to-create-a-custom-django-middleware.html – Lucas03

Antwort

0

können Sie die Reihenfolge ändern Ihre Dekorateure angewendet werden: die eine am nächsten def Linie zuerst ausgeführt wird.

@method_decorator(operation_logger) 
@method_decorator(csrf_exempt) 
def dispatch(self, request, *args, **kwargs): 
    return super(FileView, self).dispatch(request, *args, **kwargs) 
+0

Danke. Ich habe es versucht, aber nicht gearbeitet. – BAE