我已经阅读了几篇关于如何为多租户应用程序使用子域和自定义路由的文章,但我正在处理的项目只需要一个域。我们使用默认的会员资格提供商,并将加密的租户 ID 存储在 cookie 中。
我的问题是关于控制器的。我们目前正在构建它们,以便每个操作中的第一项从 cookie 中检索 TenantID,然后将其传递给每个 Linq 查询。将它移到控制器类的顶部是否安全,因此每个控制器实例只发生一次?或者如果多个用户访问同一个控制器,这是否会导致潜在的数据交叉?
我发现这篇文章表明这是可能的,但我想确定一下。
例如,这是当前系统:
public class ThisController : Controller
{
private DBContext db = new ThisContext();
public ActionResult Index()
{
long tenantid = AuthUser.GetTenantID();
...
这是我们正在考虑的:
public class ThisController : Controller
{
private DBContext db = new ThisContext();
private Int64 tenantid = AuthUser.GetTenantID();
public ActionResult Index()
{
...
我对默认行为的理解是,每个请求都会创建一个新的控制器类实例,但我想在继续之前确保它是正确的。