多租户剃刀页面
Multi Tenant Razor pages
我正在尝试设置 Razor Pages 路由以允许为不同的租户呈现不同的视图。
我的目录结构如下:
/Pages
Test.cshtml.cs
/Tenant1
Test.cshtml
/Tenant2
Test.cshtml
鉴于我已经能够决定需要哪个租户,如何配置路由以将某些路径(例如 localhost:8080/Test
映射到 Tenant1/Test
或 Tenant2/Test
视图。
使用动态视图内容(通过局部视图)。
使用此解决方案,Test
页面将根据用于调用它的路由动态加载不同的视图。
这意味着您只有一个 Test
页面,但在 cshtml
文件中,您将从局部视图中获取内容(稍后会详细介绍)。
首先,您需要像这样重命名文件....
/Pages
Test.cshtml.cs
/Tenant1
_Test.cshtml // note it is prefixed with an underscore!
/Tenant2
_Test.cshtml // prefixed with an underscore too.
The naming convention for a partial view is to prefix the file with an underscore (_
). This will immediately identify to someone looking at your project files as a "non-routable" page.
然后添加一点逻辑来呈现部分视图...
Test.cshtml
@{
switch(...) // used a switch statement to illustrate the solution
{
case "Tenant1":
await Html.PartialAsync("~/Pages/Tenant1/_Test.cshtml");
break;
case "Tenant2":
await Html.PartialAsync("~/Pages/Tenant2/_Test.cshtml");
break;
default:
throw new NotImplementedException();
}
}
您可以阅读部分视图 here。
额外:使用相同的页面模型。
我还注意到您曾想使用相同的页面模型(意味着两者共享 Test.cshtml.cs
。这相当微不足道,但为了答案的完整性,这里是您将如何做到的...
/Pages/Test.cshtml.cs
namespace Foo.Pages
{
public class MySharedTestModel : PageModel
{
...
}
}
/Pages/Tenant1/Test.cshtml 和 /Pages/Tenant2/Test.cshtml
@page
@using Foo.Pages
@model MySharedTestModel
...
我正在尝试设置 Razor Pages 路由以允许为不同的租户呈现不同的视图。
我的目录结构如下:
/Pages
Test.cshtml.cs
/Tenant1
Test.cshtml
/Tenant2
Test.cshtml
鉴于我已经能够决定需要哪个租户,如何配置路由以将某些路径(例如 localhost:8080/Test
映射到 Tenant1/Test
或 Tenant2/Test
视图。
使用动态视图内容(通过局部视图)。
使用此解决方案,Test
页面将根据用于调用它的路由动态加载不同的视图。
这意味着您只有一个 Test
页面,但在 cshtml
文件中,您将从局部视图中获取内容(稍后会详细介绍)。
首先,您需要像这样重命名文件....
/Pages
Test.cshtml.cs
/Tenant1
_Test.cshtml // note it is prefixed with an underscore!
/Tenant2
_Test.cshtml // prefixed with an underscore too.
The naming convention for a partial view is to prefix the file with an underscore (
_
). This will immediately identify to someone looking at your project files as a "non-routable" page.
然后添加一点逻辑来呈现部分视图...
Test.cshtml
@{
switch(...) // used a switch statement to illustrate the solution
{
case "Tenant1":
await Html.PartialAsync("~/Pages/Tenant1/_Test.cshtml");
break;
case "Tenant2":
await Html.PartialAsync("~/Pages/Tenant2/_Test.cshtml");
break;
default:
throw new NotImplementedException();
}
}
您可以阅读部分视图 here。
额外:使用相同的页面模型。
我还注意到您曾想使用相同的页面模型(意味着两者共享 Test.cshtml.cs
。这相当微不足道,但为了答案的完整性,这里是您将如何做到的...
/Pages/Test.cshtml.cs
namespace Foo.Pages
{
public class MySharedTestModel : PageModel
{
...
}
}
/Pages/Tenant1/Test.cshtml 和 /Pages/Tenant2/Test.cshtml
@page
@using Foo.Pages
@model MySharedTestModel
...