我正在重写一个为每个客户都有一个数据库的遗留应用程序。每个客户都有自己的身份验证和用户集。因此,我需要一个自定义身份验证后端,因为 django 的身份验证设置为仅使用默认值。我编写了中间件,在每个请求时检查 url 并在那里提取信息以在请求上设置 database_name。
如果我在处理我的自定义身份验证后端期间可以访问请求,我可以轻松地执行数据库调用,user = User.objects.using(request.db).get(username=username)
但是,我认为没有简单的方法可以完成此操作。我在这里看到了一个答案:从 backend.get_user 访问 request.session,但这似乎不是线程安全的,所以我不想走那条路。
我能看到的唯一仍然使用 django-auth 的解决方案是为每个客户设置一个身份验证后端,将数据库名称设置为类属性。然后,我将创建一个自定义登录函数,将 request.session['_auth_user_backend'] 设置为客户特定的后端。因此,当对每个请求调用 get_user(user_id) 时,它使用知道从哪个数据库请求的客户后端。
如果可能,我想避免为每个客户管理身份验证后端。有一个更好的方法吗?