- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
SCIM 标准的创建是为了通过定义表示用户和组的架构以及用于所有必要的 CRUD 操作的 REST API 来简化云中的用户管理。
它旨在取代旧的 SPML 协议(protocol)。
有没有“成熟”的 C# 库?
我用谷歌搜索过的大部分内容都是针对 Java 的,否则看起来不是很活跃。
更新:
回应评论:
这些库通常采用以下形式:
User = new User;
User.name = "name";
... etc ...
User.Create;
换句话说,它通过使用模型用户来隐藏底层实现。这样您就不必担心实际协议(protocol)的细节。
最佳答案
我已经更新了原来的答案,希望能提供一些更好的信息。
A) 这个库应该(希望)是您正在寻找的:
Microsoft.SystemForCrossDomainIdentityManagement
https://www.nuget.org/packages/Microsoft.SystemForCrossDomainIdentityManagement/
该项目的一位作者最近更新了它以包括 v1 和 v2 SCIM 对象支持,您的博客文章链接完全正确,解释了库的用途。
(作者现在将此添加到 nuget 的摘要中,这样在阅读博文之前找到 nuget 库的人就不会像我一样困惑)。
这里是一个基于 GET 请求(到 Facebook)反序列化用户的示例,您可以轻松地创建一个新的用户对象并在将其 POST 或 PUT 放入系统之前设置其属性等。
public static async Task GetUser()
{
var oauthToken = "123456789foo";
var baseUrl = "https://www.facebook.com/company/1234567890/scim/";
var userName = "foo@bar.com";
using (var client = new HttpClient())
{
// Set up client and configure for things like oauthToken which need to go on each request
client.BaseAddress = new Uri(baseUrl);
// Spoof User-Agent to keep Facebook happy
client.DefaultRequestHeaders.Add("User-Agent", "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/46.0.2490.86 Safari/537.36");
client.DefaultRequestHeaders.Accept.Clear();
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", oauthToken);
try
{
var response = await client.GetAsync($"Users?filter=userName%20eq%20%22{userName}%22");
response.EnsureSuccessStatusCode();
var json = await response.Content.ReadAsStringAsync();
// This is the part which is using the nuget library I referenced
var jsonDictionary = new JavaScriptSerializer().Deserialize<Dictionary<string, object>>(json);
var queryResponse = new QueryResponseJsonDeserializingFactory<Core1EnterpriseUser>().Create(jsonDictionary);
var user = queryResponse.Resources.First();
}
catch (Exception ex)
{
// TODO: handle exception
}
}
}
我最初使用 Newtonsoft deserialzier 而不是 MS 时遇到了一个问题:
var jsonDictionary = await Task.Factory.StartNew(() => { return JsonConvert.DeserializeObject<Dictionary<string, object>>(json); });
返回了一个 Dictionary<string, object>
但工厂无法正确使用它。
如果您使用的是 SCIM 规范的 v2,则可以使用 Core2User
或 Core2EnterpriseUser
类。
此外,我相信如果您愿意,库可以处理请求的创建(而不是自己制作它们,这看起来确实非常简单),这是项目作者 (Craig McMurtry) 的另一个片段
/*
* SampleProvider() is included in the Service library.
* Its SampleResource property provides a 2.0 enterprise user with values
* set according to the samples in the 2.0 schema specification.
*/
var resource = new SampleProvider().SampleResource;
// ComposePostRequest() is an extension method on the Resource class provided by the Protocols library.
request = resource.ComposePostRequest("http://localhost:9000");
我希望这一切都有帮助,非常感谢 Microsoft 的 Craig McMurtry,他在尝试让我启动和运行库方面提供了很大帮助 - 所以我不必自己手工制作模型类。
关于c# - C# 的 SCIM(跨域身份管理系统)库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16390464/
有没有人在 Keycloak 中使用过 SCIM?如果是这样,你能指出我的文档吗?我用谷歌搜索过,它似乎不是受支持的配置。 最佳答案 不幸的是,Keycloak 尚不支持 SCIM。他们的 Jira
我计划为我的 Azure Databricks 资源启用 SCIM 配置。 MS Doc 中提到,始终建议在帐户级别启用 SCIM,而不是在个人工作区级别启用 SCIM因此,现在如果我在帐户级别为 D
如何在 Azure 中将 scim 配置选项从自动更改为手动? 最佳答案 只有在没有自动Azure AD provision connector时才启用可用 Manual provisioning m
我需要将 SCIM 核心架构映射到 LDAP,以便 UnboundId 用于 LDAP 中的操作。 是否有更好的方法来转换这些架构? 例如在给出的模式 here我需要映射: 用户名到uid name.
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 2 年前。
我们的后端服务器不支持 HTTP PATCH 方法(仅 PUT)。因此,我们无法从 SCIM 应用程序中正确取消分配用户。 当我尝试取消分配用户时,Okta SCIM 似乎发出 PATCH 请求(而不
我实现了 SCIM API 并与 Azure 集成。 当我在 AzureAD 中删除用户时,它不会发送 DELETE 请求。我尝试从应用程序和目录中删除。 获取用户/[userID]、获取查询和 PO
我将 Azure Databricks 工作区隐藏在 VNET 中,并配置了专用链接,遵循 Microsoft 的说明. 现在我正在尝试做SCIM provisioning使用此工作区,我收到以下错误
我正在尝试在 AAD 中实现 SCIM,但在映射字段时遇到了困难。当用户被添加到组中时。在此示例中,我希望发生以下情况: (与 scim 的作用差不多) 用户已配置,用户已创建。 用户已取消配置,用户
我正在尝试在 AAD 中实现 SCIM,但在映射字段时遇到了困难。当用户被添加到组中时。在此示例中,我希望发生以下情况: (与 scim 的作用差不多) 用户已配置,用户已创建。 用户已取消配置,用户
作为 SCIM(跨域身份管理系统)标准的新手,请原谅我的无知,因为我正处于学习曲线上,试图弄清楚如何发出干净/简单的请求来配置用户、删除用户和修改用户。 我正在尝试使用 C#/.NET 通过 SCIM
我已下载 WS02 Identity Server(版本 3.2.3)并将其安装在 Windows 上。我想探索 WS02 IS 提供的 SCIM 支持。但是,我找不到任何相关信息。是否有开发人员指南
我在使用 GITHUB API 时遇到了一个奇怪的错误。当我使用 cURL 与他们联系时: curl.exe -H "Accept: application/vnd.github.cloud-9-pr
SCIM 是 Google、Salesforce、Ping Identity 等提出的用户配置的新标准。是否有现有的 ruby 实现来支持它? Similar but for Java 最佳答案
我编写了一个符合 SCIM 标准 ( https://www.rfc-editor.org/rfc/rfc7644 ) 的应用程序,但与 Azure 集成后,我可以看到,如果禁用该功能(Azure 发
当前的 Microsoft ADFS 2.0 服务器(或新的 ADFS 3.0 RTM)是否支持 SCIM 供应协议(protocol)?如果没有计划使用哪一种供应协议(protocol) SPML
我正在构建一个自定义SCIM client将连接到 Azure AD(使用企业应用程序)。我只对用户同步感兴趣,不需要组信息。 My question is if I only implement t
有人可以告诉我如何通过 SCIM 将 Microsoft Azure AD 用户配置到我自己的应用程序吗? 场景如下: 我在 Azure Active Directory 中有一些用户,希望将它们与在
我正在研究 WSO2IS,发现我可以使用 SCIM 从 WSO2 IS 创建/更新/删除/获取用户我尝试使用以下 cURL 命令 curl -v -k --user admin:admin https
SCIM 标准的创建是为了通过定义表示用户和组的架构以及用于所有必要的 CRUD 操作的 REST API 来简化云中的用户管理。 它旨在取代旧的 SPML 协议(protocol)。 有没有“成熟”
我是一名优秀的程序员,十分优秀!