[英]Multi-Tenancy in Webforms
我已经成功地使用Saaskit在MVC应用程序中实现了多租户。 应用程序为每个租户都有一个单独的数据库。 我想在Webforms项目中实现类似的功能。 谁能指出我正确的方向? 可能吗
一定有:
设法使用Webforms 4.7.2中新的Unity支持来支持此功能:
public class TenantResolver : ITenantResolver
{
public Tenant GetTenant()
{
var identifier = HttpContext.Current.Request.Url.Host.ToLower();
return AllTenants().FirstOrDefault(x => x.HostNames.Any(a => a.Hostname.Contains(identifier)));
}
public List<Tenant> AllTenants()
{
// return list of tenants from configuration or seperate db
}
}
在启动中
void Application_Start(object sender, EventArgs e)
{
// Code that runs on application startup
RouteConfig.RegisterRoutes(RouteTable.Routes);
BundleConfig.RegisterBundles(BundleTable.Bundles);
var container = this.AddUnity();
container.RegisterType<ITenantResolver, TenantResolver>();
container.RegisterType<ApplicationContext, ApplicationContext>();
}
可以访问租户的示例页面
public partial class About : Page
{
readonly Tenant tenant;
readonly ApplicationContext _context;
public About(ITenantResolver tenantresolver, ApplicationContext context)
{
tenant = tenantresolver.GetTenant();
_context = context;
}
protected void Page_Load(object sender, EventArgs e)
{
}
}
每个租户具有db的示例数据库上下文
public class ApplicationContext : DbContext
{
public ApplicationContext(ITenantResolver tenantResolver) : base(ConnectionStringResolver(tenantResolver)) {
}
private string ConnectionStringResolver(AppTenant appTenant)
{
var tenant = tenantResolver.GetTenant();
if (tenant != null)
{
return tenant.ConnectionString;
}
throw new NullReferenceException("Tenant Not Found");
}
}
默认成员资格API应该足以满足要求。
如果没有,请考虑http://www.asp.net/general/videos/how-do-i-create-a-custom-membership-provider
请参考教程> http://www.asp.net/security/tutorials
影片http://www.asp.net/security/videos
最佳实践在上述教程中进行了说明。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.