- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
作为 SCIM(跨域身份管理系统)标准的新手,请原谅我的无知,因为我正处于学习曲线上,试图弄清楚如何发出干净/简单的请求来配置用户、删除用户和修改用户。
我正在尝试使用 C#/.NET 通过 SCIM 为用户发出 HTTP REST 请求,使用 System.Net.Http.HttpClient
https://msdn.microsoft.com/en-us/library/system.net.http.httpclient(v=vs.110).aspx
我可以成功完成此操作并从服务器获得 JSON 响应,但是为了轻松读取响应对象并对其进行操作,我想对其进行反序列化。经过大量阅读尝试使用诸如 JsonConvert 之类的东西
、dynamic
等。我偶然发现了一个 Microsoft nuget 库,它似乎暗示有用。可悲的是,似乎没有任何文档*
更新:其中一位作者更新了 nuget 页面,其中包含指向博客文章的链接,该链接在某种程度上解释了用法。
Microsoft.SystemForCrossDomainIdentityManagement
https://www.nuget.org/packages/Microsoft.SystemForCrossDomainIdentityManagement/
我尝试从 Facebook 获取数据的 SCIM 提供商是 Facebook,使用他们在其网站上发布的示例,通过电子邮件获取用户:
https://developers.facebook.com/docs/facebook-at-work/provisioning/scim-api#getuserbyemail
这是 C# 中的代码示例,它尝试从 SCIM 服务获取用户并反序列化它们。我发现我返回的 queryResponse
在属性被填充时被正确反序列化,但是 Core1EnterpriseUser
这是第一个也是唯一的资源对象,具有 null/默认属性。
var userName = "foo.bar@foobar.com";
var response = await client.GetAsync($"Users?filter=userName%20eq%20%22{userName}%22");
if (response.IsSuccessStatusCode)
{
var json = await response.Content.ReadAsStringAsync();
var jsonResponseProperties = await Task.Factory.StartNew(() => { return JsonConvert.DeserializeObject<Dictionary<string, object>>(json); });
var userFactory = new QueryResponseJsonDeserializingFactory<Core1EnterpriseUser>();
var queryResponse = userFactory.Create(jsonResponseProperties);
if (queryResponse.TotalResults == 1)
{
var user = queryResponse.Resources.First();
var id = user.Identifier; // this and other properties are null/false etc.
}
}
这是我查询服务时返回的 JSON 示例:
{
"schemas": [
"urn:scim:schemas:core:1.0"
],
"totalResults": 1,
"itemsPerPage": 10,
"startIndex": 1,
"Resources": [
{
"schemas": [
"urn:scim:schemas:core:1.0",
"urn:scim:schemas:extension:enterprise:1.0",
"urn:scim:schemas:extension:facebook:starttermdates:1.0",
"urn:scim:schemas:extension:facebook:suppressclaimemail:1.0"
],
"id": 180383108978226,
"userName": "foo.bar\u0040foobar.com",
"name": {
"formatted": "Foo Bar",
"familyName": "Bar",
"givenName": "Foo"
},
"title": "Vice President",
"active": true,
"emails": [
{
"primary": false,
"type": "work",
"value": "foo.bar\u0040foobar.com"
}
],
"urn:scim:schemas:extension:enterprise:1.0": {
"department": "IT"
},
"urn:scim:schemas:extension:facebook:starttermdates:1.0": {
"startDate": 0,
"termDate": 0
}
}
]
}
更新:
我正在与该项目的一位作者进行对话,他亲切地向我指出了这篇博文:
他还更新了 nuget 库,现在包括对 SCIM v1 的支持,还指出 JSON 数据表明 Facebook 使用的版本是 v1:"urn:scim:schemas:core:1.0"
所以现在我可以使用 Core1
而不是尝试使用 Core2
类(我已经更新了上面的问题以使用 Core1EnterpriseUser
) .
我目前仍然无法获得我的反序列化响应的正确性,并将在我获得更多信息时更新问题。
同样,如果很明显它不容易工作,我不必使用这个库,因为我知道 nuget 的简短描述表明它是为 Azure AD 创建的。
但是,我很感激任何关于如何/应该如何完成此类事情的建议,因为我确信肯定有很多人在使用 SCIM - 你如何解析你的响应/生成你的请求,以便你有实物吗?您能否自动解析模式的响应,以便使用正确的属性扩充对象?
我昨晚很晚才手工制作一些模型类来处理响应对象 - 我似乎确实在工作。如果我不能让 nuget 库工作(首选选项),那么我将不得不使用我自己的库。 :/
再次感谢佩特斯基
最佳答案
虽然我仍然不了解 SCIM 的最佳实践,但我现在已经设法让代码正常工作 - 非常感谢微软的 nuget 库的作者之一 Craig McMurtry!
在此过程中有一些事情需要解决,例如更新 nuget 包以包括以前对旧 v1 SCIM 对象的支持。但这是基于我的问题中的示例的工作片段,但结果证明它使用的是 Newtonsoft 序列化程序。 :(
在行上方的代码中:
var jsonResponseProperties = await Task.Factory.StartNew(() => { return JsonConvert.DeserializeObject<Dictionary<string, object>>(json); });
被替换为:
var jsonResponseProperties = new JavaScriptSerializer().Deserialize<Dictionary<string, object>>(json);
瞧瞧!我的对象的属性现在正在反序列化...
关于c# - .NET 中的 SCIM 反序列化问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34065456/
有没有人在 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)。 有没有“成熟”
我是一名优秀的程序员,十分优秀!