2016-07-22 10 views
1

私のREST APIを実行しているカスタマイズされたデコレータ:ジャンゴ:ジャンゴ・静止フレームワークの認証クラスの前に

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" 

カスタマイズされたデコレータ:

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 

認証が完了する前に私のデコレータが動作しているようです。それを修正するには? ありがとう

更新 下記のミドルウェアリストを追加しました。しかし、私はdjangorestframeworkを使用しているAPIのためのブランチ新しいアプリケーションを作成したので、それが関連しているかどうかはわかりません。 1最寄りdefへのラインが最初に実行されます:

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

ミドルウェアの注文は何ですか? http://simpleisbetterthancomplex.com/tutorial/2016/07/18/how-to-create-a-custom-django-middleware.html – Lucas03

答えて

0

はあなたのデコレータが適用される順序を変更することができます。

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

ありがとうございました。私は試しましたが、仕事はしません。 – BAE

関連する問題