gpt4 book ai didi

asp.net-mvc - 具有多个应用程序的ASP.NET Identity

转载 作者:行者123 更新时间:2023-12-01 16:22:15 25 4
gpt4 key购买 nike

因此,我们的组织正在使用ASP.NET MVC和Web API开发一些新的Web应用程序。我们决定不将事件目录用于身份验证/授权目的,因此看起来带有 Entity Framework 的asp.net身份可能有效。

在查看数据库模式时,我没有看到一个应用程序表,因此我们可以为用户凭据和应用程序访问提供一个中央存储库。这是 claim 的地方吗?看起来如何?用户->应用->角色->权限

同样,我们的目标之一是也为用户提供单点登录。新的承载 token 有可能吗?

感谢您的任何帮助,您可以提供

最佳答案

看一下本教程。它显示了如何使用Web API来实现ASP.NET Identity:

http://bitoftech.net/2015/01/21/asp-net-identity-2-with-asp-net-web-api-2-accounts-management/

至于处理多个应用程序。我想到的两种方法是:

  • AppId附加到所有用户名
  • 将一个AppId列添加到AspNetUsers表中,从UserStore派生并重新实现基于Find的方法,以便查询考虑AppId

  • 对于#1,当应用程序要创建新用户时,它将向WebApi发送包含新用户信息和 AppId的请求。然后,WebApi将连接 UserNameAppId以创建将写入数据库的完整用户名。因此,如果应用程序 1234想要使用用户名 myuser创建一个用户,则WebApi将使用用户名 myuser_1234创建一个新用户。从那时起,在查询数据库时,您将首先从请求中获取 UserNameAppId,将它们连接起来,然后查询数据库。

    如果另一个应用程序 9900想要创建一个 myuser,那么写入数据库的最终用户名将是 myuser_9900

    您可能希望将应用程序详细信息存储在数据库中,并针对每个请求验证 AppId以确保在处理其请求之前识别出该应用程序。

    我没有对步骤2进行太多考虑,因此这只是一个建议。

    如果要在多个应用程序之间共享用户凭据,则可以忽略上述内容,使用标准功能,并且所有应用程序都指向同一数据库,因此,无论哪个应用程序创建了哪个用户,所有应用程序都可以访问所有用户。

    更新#1:在这种情况下,可以使用承载 token ,我认为(从内存中获取)上面提到的教程系列触及了这一点,以及单个WebApi如何可以为多个应用程序提供 token 。

    关于asp.net-mvc - 具有多个应用程序的ASP.NET Identity,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29415831/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com