- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们正在 Azure 中开发 Multi-Tenancy SaaS 产品,该产品具有 AngularJS 前端和 Web API 后端。我们使用 Azure AD 进行身份验证,并将其与 ADAL JS 连接起来(使用 OAuth2 隐式授权)。作为一个 Multi-Tenancy 应用程序,我们允许客户根据自己的 Azure AD(可能会也可能不会连接到本地 AD)进行身份验证。
到目前为止,一切都很顺利。 ADAL JS 将用户带到 Azure 登录页面,用户经过身份验证后,就会颁发 OAuth2 token 。然后,此 JWT token 作为不记名 token 与所有 API 调用一起发送,我们有自己的声明转换过程,用于将来自 Azure 的传入声明映射到我们的应用程序声明。
我们尝试通过 AD 组来完成此操作,而不是在声明转换过程中指定单个用户。这允许我们的客户在他们的 AD 中拥有安全组,然后我们的应用程序将使用它来映射到正确的应用程序声明。
尽管我们在 AAD 应用程序 list 中将 groupMembershipClaims
设置为 SecurityGroup
,但我们收到的 JWT token 不包含 groups
属性。我后来读到了this tweet from Vittorio那个
The implicit grant will NOT send those claims, as it returns the token in the querystring - it's easy to blow past max length
经过进一步调查,我还发现this StackOverflow answer from Vittorio这说的是
I verified and in the implicit grant case you will receive groups always via the overage claim. Please refer to https://github.com/AzureADSamples/WebApp-GroupClaims-DotNet/tree/master/WebApp-GroupClaims-DotNet - it will show you how to process the overage claim to retrieve groups.
我查看了 JWT token ,它不包含任何超额声明(由 _claim_names
和 _claim_sources
标识)。我绝对是 Azure AD 中两个组的成员。
关于是否可以在隐式授予 token 中获取组信息(无论是直接还是间接),我现在似乎还有两个相互矛盾的陈述。
问题 1:我是否应该获得可用于获取团体信息的超额 claim ?如果是这样,我需要做些什么来确保 claim 被发送给我吗?
无论我是否可以通过图形 API 中的用户链接获得超额 claim ,或者是否必须手动创建链接来获取用户组,我仍然有点不确定如何使用图形 API 进行身份验证。
在收到带有不记名 token (来自 ADAL JS)的请求后,我需要从后端联系图形 API。
问题 2:我可以将相同的不记名 token 发送到图形 API 来读取该用户的目录信息吗?或者我是否需要在应用程序上下文中直接从我的应用程序向图形 API 租户进行身份验证,而不是用户?
最佳答案
对于此处的困惑表示歉意。我会仔细检查有关超额的声明,但无论如何 - 为了快速解锁您,我们假设您需要在没有超额声明帮助的情况下手动获取组。您无法重复使用发送到 Web API 的 token 。该 token 的范围仅限于您的应用程序,任何其他接收者都会(或应该)拒绝它。好消息是,后端可以请求图形范围内的新 token 的流程很容易实现。请参阅https://github.com/AzureADSamples/WebAPI-OnBehalfOf-DotNet - 您的案例的详细信息有点不同(您的 Web API 具有应用程序的受众 == clientid),但涉及的拓扑和代码/调用完全相同。哈!五、
关于angularjs - 在 ADAL JS 中使用 Azure AD 和 OAuth2 隐式授予对声明进行分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29762551/
我刚刚更新了 Ruby,现在我在尝试启动 compass 时遇到以下错误: Encoding::CompatibilityError on line ["28"] of /usr/local/Cell
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 6 年前。
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在尝试在我的 iOS 应用程序中开发可折叠/ Accordion 式的功能。这将是您可以在网站上找到的典型 FAQ 类型功能。我想点击标题,然后显示详细信息。 因为这是帮助部分,只有几个项目,我认
我正在尝试设计一个基于 REST 的 Web 服务来与我正在开发的农场动物管理系统进行交互。 为了详细说明问题,我收藏了动物 属于一个农场。每只动物都有自己的信息——例如姓名、身份证号、品种年龄等。因
我有 3 种不同的表单,其中复选框数量不同,每个部分基本上代表一个表单,因此当用户选择该部分中的复选框时,它会显示他们在该部分的总金额中 checkout 了多少 HTML
我有一份 32 页的 PDF 版家谱。与其将家谱全部放在一个非常大的 PDF 页面上(这是我想要的),不如将其格式化为一组 8 个单独的美国信纸大小的页面应该在整个宽度上缝合; 4 行这样就完成了树。
指SASS implementation for Java? : 在 Maven 目标编译包中自动编译 compass-style.org 样式表的最佳方法是什么? 我不想发送太多的自编译库,也不想通
鉴于以下 XAML... 我正在寻找一种绑定(bind) ComboBox、Button 和 Command 的方法,以便当 ComboBox 的值更改时,在 Command 上调用 CanExe
在玩具应用程序中,我有一个显示所有帖子标题的“帖子”模板。当您单击每个标题时,我不想直接进入“显示” View ,而是直接内联展开该帖子的其余内容。 我考虑过让 postRoute 重用 postsR
我需要一些使用 Twitter Bootstrap 或其他响应式框架的自定义 Swagger-UI 实现。需要在我的移动设备上使用这样的 UI 测试我的 API,但 swagger-ui 不能很好地扩
我正在做一个项目,我真的在尝试编写面向对象的 JavaScript 代码。我刚刚开始阅读Douglas Crockford's JavaScript: The Good Parts我很快开始意识到用
在 C# 中,我通过执行以下操作来加密文本数据(请注意我正在以 block ( block )的形式加密数据): public string EncryptData(string pu
我正在构建一个社交网站,该网站将向全世界公开 REST API (WCF WebAPI),以便任何开发人员都能够为该网站创建客户端应用程序、将其与其他服务集成等。 我想为 API 实现 Faceboo
我是一名优秀的程序员,十分优秀!