比如有下面一个View,比较简单:
class UsersView(View):
def get(self,request):
......
这个GET方法会接受一个参数id
,也就是用户的ID,理想的状态是只要进入get方法内,那么这个用户就是存在的,否则就直接抛404或者其他。
但现在的做法是在view里面做判断用户是否存在,然后再做不同的操作。
class UsersView(View):
authentication_classes = ....
permission_classes = ....
serializer_class = ....
不知道rest
里面有没有这种方法,可以在进入View里面之前就可以做参数的验证,而不用在View里面。
リクエストできないリソースは自動的に 404 エラーをスローします
Rest のビューには、authentication_classes が設定されています。このメソッドでは、カスタマイズされた認証クラスを作成し、authentication.BaseAuthentication クラスを継承して、authentication(self, request) メソッドを実装することができます。論理判定を行い、対応するエラー情報等を返します。
ただし、これは主に現在リクエストしているユーザーの認証に使用されます。たとえば、ID が存在するかどうかを判断するためにビューに記述するのが通常です。複数のビューで必要な場合は、デコレータを記述することができます。