0

我们正在为一个应用程序编写一个 SCIM 提供程序,它适用于 Azure AD。该代码已使用 Microsoft.SystemForCrossDomainIdentityManagement 实现。

我们正在尝试支持 oneLogin 并且创建工作正常,但是在测试更新功能时它失败了,因为 Id 仅在请求中而不在正文中。

public class MyProvider : ProviderBase, IProvider
{
    public override Task<Resource> ReplaceAsync(Resource resource, string correlationIdentifier)
    {
        switch (resource)
        {
            case Core2User user:
            var existingUser = GetUser(applicationId, user.Identifier);

        }
    }
}

因此,该方法对 ID 没有任何想法,并且由于 user.Identifier 为空而失败。

我试图在他们网站上的文档之后在 schima 中添加 id,但 id 实际上是他们的 id,而不是我们传递给他们的那个。

{"schemas":["urn:ietf:params:scim:schemas:core:2.0:User"],
"active": "{$user.status}",
 "emails": {
        "value": "{$user.email}",
        "type": "work",
        "primary": true
    },
"userName":"{$parameters.scimusername}",
    "id": "{$user.id}",
    "name": {
        "givenName": "{$user.firstname}",
        "familyName": "{$user.lastname}",
        "formatted": "{$user.display_name}"
    }
}

如何解决这个问题?

4

1 回答 1

0

显然,唯一的方法是检查请求是否为空。

 string id = resource.Identifier ?? HttpContext.Current.Request.Path.Substring(HttpContext.Current.Request.Path.LastIndexOf("/", StringComparison.InvariantCulture) + 1);
于 2019-04-04T14:55:42.587 回答