.Net Core API相同的URL,不同的租户有效负载

问题描述

我正在一个项目上进行工作,该项目不是完全多租户的,但是我们有多个具有内部部署应用程序的客户,其中一项要求是为所有这些应用程序使用单个代码库。当前,每个客户要么拥有原始代码库的分支,要么在公共仓库中拥有一个特殊的分支。 多年来,定制代码一直是每种模式的模式,这导致数据库,业务逻辑和前端方面的差异。

对于我们正在构建的REST API,我试图找到一种干净的方法为每个客户端使用相同的url,但是有效负载也会有所不同。我需要能够根据配置调用适当的控制器。 对于clientA,POST / api / visitor的有效负载形状可能为{Name,Age},clientB的有效负载形状可能为{Name,CardNumber,Height}。

我试图将控制器移动到解决方案中的自己项目中,并使用AddApplicationPart(clientAssembly),但是由于所有项目都在api项目中被引用,所以endpoints.MapControllers()由于名称冲突而崩溃。如果我进行这项工作,由于项目引用的原因,将需要为每个客户部署代码,我认为这不是一个好主意。

我还研究了使用新的.net核心3动态路由功能,但我认为它应该用于转换请求,而不是向其添加上下文。

有人碰到这个吗?我是否应该跳过所有这些,并在每条路线的URL中都包含“租户”(此解决方案可能会被拒绝)?

解决方法

您可以尝试创建多个版本的API。下面是一个非详尽的示例,但可以将您的问题映射到解决方案领域。这将帮助您使您的域,API和服务与映射到它们自己的版本共存。同样,在以后的某个时间点,您可以将旧版本的API使用者迁移到最新版本,并停止维护非常旧的版本(例如使过时的版本)。我们今天在网络上发布的大多数公共API都遵循此模型。

namespace Models.V1.Customer {
    public class Customer {

        public Guid Id;
        public string Name;
        public string Address;
        public int Zip;
    }
}

namespace Models.V2.Customer {
    public class Customer: Models.V1.Customer {
        public Location CustomerLocation;
    }
}


[RoutePrefix("api/customers/")]
public class CustomerAPIController : IHttpController {

    [Route("v1/byId/{Id}")]
    public Models.V1.Customer GetCustomerById(Guid Id) {
        // calls to get the customer data by id
    }

    [Route("v2/byId/{Id}")]
    public Models.V2.Customer GetCustomerById(Guid Id) {
        // calls to get the customer data by id
    }
}

您可以从here

了解有关此主题的更多信息

希望这可以澄清您的问题。