djangoで独自の認証処理のためにミドルウェアを作成しました。
そこで質問なんですが、このミドルウエアを特定ページに適用する方法として、
urls側での設定方法はありますでしょうか?
クラス名で振り分けの方法は見つけたのですが、
同一名を使用しているクラスもあり、使えません。
また現状、request.pathで判定して作成していますが、
こちらも同一ディレクトリ配下でミドルウエアが不要の場合にif文が増えていってしまいます。
できればPHPのlaravelのようにルーティングで制御できればと思っています。
よろしくお願いします
現状のミドルウエアです
class AuthMiddleware: def __init__(self, get_response): self.get_response = get_response def __call__(self, request): response = self.get_response(request) return response def process_view(self, request, view_func, view_args, view_kwargs): #現在パスで指定していますが条件分岐が増えていきそうであまり良くなさそうです if request.path.startswith('/user/login'): return None elif request.path.startswith('/user/'): if 'auth' not in request.session: return redirect('/user/login') else: return None
あなたの回答
tips
プレビュー