- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个 MVC Web 应用程序(WebAPI + Angular)作为 Web 应用程序(不是 API 应用程序)部署到 Azure,该应用程序设置为使用“设置”->“身份验证/授权”->“AAD”->“Express”进行保护。这将创建一个与 Web 应用程序同名的 AD 应用程序,并且作为普通 Web 用户(在目录中,使用 OAuth),这将按预期工作。
但我也有需要直接调用 WebAPI Controller 的外部自动化,因此我需要以编程方式获取承载 token 来传递这些请求。
当“访问应用程序需要用户分配”==否时,一切正常。但这还不够,因为目录中的每个人都不应有权访问此应用程序。
翻转该开关会导致错误:
Application 'AppId' is not assigned to a role for the application 'AppId'.
正在使用的代码:
var aadLoginUri = "http://login.microsoftonline.com/{0}";
var tenantId = "[xxx].onmicrosoft.com";
var authority = String.Format(CultureInfo.InvariantCulture, aadLoginUri, tenantId);
var clientId = ConfigurationManager.AppSettings["ClientId"];
var clientSecret = ConfigurationManager.AppSettings["ClientSecret"];
var authContext = new AuthenticationContext(authority);
ClientCredential clientCredential = new ClientCredential(clientId, clientSecret);
AuthenticationResult authResult = authContext.AcquireToken(clientId, clientCredential);
如何为应用程序添加角色分配?
(与用户相反)
我尝试利用“对其他应用程序的权限”部分,但应用程序无法添加到自身。为了看看这是否可以解决另一个应用程序的问题,我继续创建了一个应用程序,并且能够添加该应用程序并将委托(delegate)权限设置为“访问[应用程序名称]”。但与以前一样,这仅在不需要用户分配即可访问应用程序的情况下才有效。之后 AcquireToken()
抛出相同的异常。
好像是这个问题could be solved通过将我们的 API 与 Angular 应用程序解耦,将 API 作为 API 应用程序(带有网关)托管,但目前这不是一个选择。另外this article说这个新的身份验证功能“取代了大多数应用程序的应用服务网关”和 this blog post在 11 月宣布该功能时说“我们建议 Web 和移动应用程序使用此功能,而不是 future 的应用服务网关”,所以我想知道这是否还没有进入 UI,也许有可能通过应用程序 list (尝试过,失败)、graph/service-mgmt api、powershell 等添加应用程序角色分配。
最佳答案
关键是在 list 中定义正确的 appRoles(使用正确的 allowedMemberType)。
在 Azure 门户中,配置以下内容:
在需要访问的资源中,打开 list (“应用注册”边栏选项卡)。在 appRoles 数组中,添加两个角色:
保存 list 。
接下来,在需要访问资源的客户端应用中:
配置用户权限:
在“属性”部分中,保留“需要用户分配吗?”复选框已启用。这将仅限制对已配置用户的访问。
现在您可以作为用户和应用程序访问资源。
关于c# - Azure AD 应用程序 - 需要角色分配 + 为应用程序添加角色分配?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34444812/
似乎有很多方法可以在 Azure 中自动使用 PowerShell。由于 ARM 模板是最新的,Azure 中的其他 PowerShell 选项是否已过时?这些工具/脚本之间有什么区别: Azure
我正在开发一个将托管在 Azure 中的 Web API。我想使用 Azure 诊断将错误记录到 Azure 表存储中。在经典门户中,我可以将日志配置为转到 Azure 表存储。 Classic Po
Azure 文件存储事件可以触发 Azure WebJob 或 Azure Function 吗? 例如,在文件夹“/todo/”中创建文件时。 最佳答案 我们目前没有任何 Azure 文件绑定(bi
我需要创建一个逻辑应用程序,我的要求是,我需要从 azure data Lake Gen2 文件夹迁移 json 文件,并根据某些值需要将该 json 转换为 xml,然后将其发送到 SQL。 因此,
我使用 VS Code 创建了 1 个 node.js 和 1 个 java Azure Function 当我使用 VS Code 将这两个函数部署到 Azure 时,我最终获得了这么多 Azure
收集 Azure 诊断数据时,暂存槽是否也会将诊断数据发送到 WadPerformanceCounters 表? 如果是这样,我该如何关闭它?或者在阅读诊断信息时如何区分暂存/生产。 我不想显示有关我
您好,我是 Azure 的新手。我有 VS 2012 和 Azure SDK 2.1,当我使用模拟器运行我的 Web 应用程序时一切正常。但是当我在 azure 上部署时出现错误消息: Could n
我很难区分 Azure 订阅和 Azure 租户有何不同?我尝试使用示例来弄清楚,但每次我得出的结论是它们在某种程度上是相同的?如果租户是组织在注册 Microsoft 云服务时接收并拥有的 Azur
如果我想在 Azure Insights 中设置自定义指标集合,并以(近)实时的方式可视化其中一些指标,并查看聚合的历史数据,我应该使用 Azure Metrics Explorer 还是 Azure
我想了解具有以下配置的 Azure 数据工厂 (ADF) 的现实示例/用例: Azure 集成运行时 (AIR) 默认值 自托管集成运行时(SHIR) 其他问题: 这两种配置(AIR 和 SHIR)是
请参阅下面来自 Azure 服务总线的指标。想要识别请求数量中的背景噪音|流量较低时的响应。假设振荡请求| session 中 amqp 握手的响应是潜在的。只是不明白这是什么类型的握手?从总线接收的
此问题与 Azure 事件中心和 Azure 服务总线之间的区别无关。 问题如下: 如果您将Azure Events Hub添加到您的应用程序中,那么您会注意到它依赖于Azure Service Bu
这两个事情是完全不同的,还是它们能完成的事情大致相同/相似? 最佳答案 Azure 辅助角色是“应用程序场”中您自己的一组虚拟机。您可以以分布式方式在它们上运行任何代码。通常,您编写业务代码以在这些服
我目前正在使用 Windows Azure 虚拟机来运行 RStudio, 我的虚拟机是 Windows Server R2 2012,它是 Azure 上的一项附加服务。 我还有一个 Azure 存
我们正在寻找托管一个网站(一些 css、js、一个 html 文件,但不是 aspx、一个通用处理程序)。 我们部署为: 1) Azure 网站 2) Azure 云服务 两种解决方案都有效。但有一个
我想从 Azure 表创建 blob。 AzCopy 支持此功能,但我找不到任何说明数据移动 API 也支持它的文档。此选项可用吗? https://azure.microsoft.com/en-us
This article表示 Azure 订阅所有者有权访问订阅中的所有资源。但是,要访问 Azure 数据库,必须是数据库中的用户,或者是 Azure Admin AD 组的成员。 无论 SQL 安
我尝试使用以下代码将 XML 文件上传到 Azure FTP 服务器: https://www.c-sharpcorner.com/article/upload-and-download-files-
除了 Azure 服务总线使用主题而 Azure 事件中心基于事件 - Azure 事件中心和 Azure 服务总线之间是否有任何根本区别? 对我来说,事件和消息之间没有真正的区别,因为两者只是不同类
我有一个通过虚拟网络网关连接到 Azure 虚拟网络的 Windows VPN 客户端。目标#1 是使用其内部 IP 地址连接到我的虚拟机。这有效。 第二个目标是使用其内部计算机名称进行连接(因为 I
我是一名优秀的程序员,十分优秀!