Azure App object和Service Principal
为了把Identity(身份)和Access Management function(访问管理功能)委派给Azure AD,必须向Azure AD tenant注册应用程序。使用Azure AD注册应用程序,实际是为应用程序创建一个身份配置,以使其能够与Azure AD集成。 在Azure门户中注册应用程序时,可以选择是单租户(仅在您的租户中可访问)还是多租户(在其他租户中可访问),并且可以选择设置重定向URI,这是访问令牌(Access Token)被发送到的位置 。
当在Portal中注册app时,home tenant会自动创建app instance和service principal。
一,通过UI注册App
登录到Azure Portal中,选择“Azure Active Directory”服务,从Overview选项卡中点击“App registration”:
注册App的页面如下图所示:
1,Supported Account 类型
共有四种类型的Suppored Account:
- Accounts in this organizational directory only (Microsoft only - Single tenant):只为自己tenant中的用户创建一个app,简称为single-tenant app
- Accounts in any organizational directory (Any Azure AD directory - Multitenant):任意AD tenant中的用户都能够使用该app,简称为multi-tenant app。
- Accounts in any organizational directory (Any Azure AD directory - Multitenant) and personal Microsoft accounts (e.g. Skype, Xbox):支持multi-tenant,并支持个人的微软账户(personal Microsoft account)
- Personal Microsoft accounts only:只为个人微软账户(Personal Microsoft account)使用的app
2,Redirect URI
这个配置项是可选的,成功验证身份后,Azure AD把身份验证的响应(Response)返回到此URI。
3,App Instance
当完成app的注册后,一个App对象的全局唯一实例就创建成功了,该实例位于home tenant 或 directory中,并且该app instance拥有一个GUID,称作App ID 或 Client ID。
可以向Portal中添加Secret或Certificate和Secret Scope,使得App可以工作。
二, Application Object
Azure AD应用程序是由其唯一的应用程序对象定义的,该对象位于应用程序注册所在的Azure AD租户(称为应用程序的“主”租户)中。 应用程序对象用作创建一个或多个服务主体(Service Principal)对象的模板或蓝图。 在使用该应用程序的每个租户中都会创建一个服务主体。与面向对象编程中的class相似,应用程序对象具有一些静态属性,这些属性应用于所有已创建的服务主体(或应用程序实例)。
应用程序对象描述了一个应用程序的三个方面:服务如何发出令牌以访问应用程序,应用程序可能需要访问的资源以及应用程序可以采取的操作。
“App registrations” 用于列出和管理home tenant中的app:
三,Service Principal
如果一个实体需要访问由Azure AD租户保护的资源,那么该实体必须由安全主体(security principal)所代表。此要求对用户(用户主体)和应用程序(服务主体)均适用。安全主体定义Azure AD租户中用户/应用程序的访问策略和权限,例如登录期间对用户/应用程序的身份验证以及资源访问期间的授权。
服务主体(service principal)是单个租户或目录中全局应用程序对象的本地表示形式(或应用程序实例)。服务主体是从应用程序对象创建的具体实例,并从该应用程序对象继承某些属性。在使用该应用程序的每个租户中创建一个服务主体,并引用全局唯一的应用程序对象。服务主体对象定义了应用程序可以在特定租户中实际执行的操作,可以访问该应用程序的人员以及该应用程序可以访问的资源。
当一个应用程序被授予访问租户中资源的权限时(注册或同意时),同时创建一个服务主体对象。您还可以使用Azure PowerShell,Azure CLI,Microsoft Graph,Azure门户和其他工具在租户中创建服务主体对象。如果使用门户 UI,那么在注册应用程序时会自动创建服务主体。门户中的Enterprise applications用于列出和管理租户中的服务主体,并可以看到服务主体的权限,用户同意的权限,用户已经同意的权限,登录信息等等。
四,Application 对象和Service Principal之间的关系
应用程序对象是在所有租户中使用的应用程序的全局表示形式,服务主体是在特定租户中使用的本地表示形式。应用程序对象用作模板,从该模板派生通用属性和默认属性以用于创建相应的服务主体对象。 因此,应用程序对象与软件应用程序具有1:1的关系,与其对应的服务主体对象具有1:many的关系。 注意,必须在使用该应用程序的每个租户中创建一个服务主体,使其能够为登录(sign-in)和/或访问由该租户保护的资源建立身份。单租户(single-tenant)的应用程序只有一个服务主体(在其home租户中),该Service Principal在在应用程序注册期间被创建。多租户(multi-tenant)的Web应用程序/ API在每个租户中都会创建一个服务主体,来自该租户的每个用户都使用该服务主体。
注意,对应用程序对象所做的任何更改只会反映到在应用程序的home租户(注册该租户的租户)中的服务主体对象。 对于多租户应用程序,对应用程序对象的更改不会反映在任何消费者租户的服务主体对象中,除非通过“Application Access Panel”把权限删除,并再次授予访问权限。 另请注意,默认情况下,本机应用程序已注册为多租户。
参考文档:
Microsoft identity platform documentation
Application and service principals
Quickstart: Register an application with the Microsoft identity platform
Azure App object和Service Principal的更多相关文章
- 如何将Azure DevOps中的代码发布到Azure App Service中
标题:如何将Azure DevOps中的代码发布到Azure App Service中 作者:Lamond Lu 背景 最近做了几个项目一直在用Azure DevOps和Azure App Servi ...
- 手把手:使用service principal连接Azure Media Service
在简书中查看,请点击我. 关于相关内容解释,请参考docs文档 https://docs.microsoft.com/en-us/azure/media-services/previous/media ...
- Azure登陆的两种常见方式(user 和 service principal登陆)
通过Powershell 登陆Azure(Azure MoonCake为例)一般常见的有两种方式 1. 用户交互式登陆 前提条件:有一个AAD account 此种登陆方式会弹出一个登陆框,让你输入一 ...
- AAD Service Principal获取azure user list (Microsoft Graph API)
本段代码是个通用性很强的sample code,不仅能够操作AAD本身,也能通过Azure Service Principal的授权来访问和控制Azure的订阅资源.(Azure某种程度上能看成是两个 ...
- 改善Azure App Service托管应用程序性能的几个技巧
本文介绍了几个技巧,这些技巧可以改善Azure App Service托管应用程序的性能.其中一些技巧是你现在就可以进行的配置变更, 而其他技巧则可能需要对应用程序进行一些重新设计和重构. 开发者都希 ...
- 【应用服务 App Service】Azure App Service 中如何安装mcrypt - PHP
问题描述 Azure App Service (应用服务)如何安装PHP的扩展 mcrypt(mcrypt 是php里面重要的加密支持扩展库) 准备条件 创建App Service, Runtime ...
- 【应用服务 App Service】在Azure App Service中使用WebSocket - PHP的问题 - 如何使用和调用
问题描述 在Azure App Service中,有对.Net,Java的WebSocket支持的示例代码,但是没有成功的PHP代码. 以下的步骤则是如何基于Azure App Service实现PH ...
- 【应用服务 App Service】当遇见某些域名在Azure App Service中无法解析的错误,可以通过设置指定DNS解析服务器来解决
问题情形 当访问部署在Azure App Service中的应用返回 "The remote name could not be resolved: ''xxxxxx.com'" ...
- 【Azure App Service】C#下制作的网站,所有网页本地测试运行无误,发布至Azure之后,包含CHART(图表)的网页打开报错,错误消息为 Runtime Error: Server Error in '/' Application
问题描述 C#下制作的网站,所有网页本地测试运行无误,发布至Azure之后,包含CHART(图表)的网页打开报错,错误消息为 Runtime Error: Server Error in '/' Ap ...
随机推荐
- JavaScript:常用的一些数组遍历的方法
常用的一些遍历数组的方法: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...
- STL——容器(Map & multimap)的删除
Map & multimap 的删除 map.clear(); //删除所有元素 map.erase(pos); //删除pos迭代器所指的元素,返回下一个元素的 ...
- mysql 8.0 改变数据目录和日志目录(一)
一.背景 原数据库数据目录:/data/mysql3306/data,日志文件目录:/data/mysql3306/binlog 变更后数据库目录:/mysqldata/3306/data,日志文件目 ...
- JavaSE07-字符串常用API
1.String 1.1 String类概述 String 类代表字符串,Java 程序中的所有字符串文字(例如"abc")都被实现为此类的实例.也就是说,Java 程序 中所有的 ...
- js上 十二、函数初步-1
11-1.引入(认识函数) 引入: 说起函数,其实我们并不陌生,在初中数学中我们就接触过函数:例如我们所学的 y = 2X+1 ; 这是一个二元一次方程,也是我们数字中的函数: 当我们每次输入 ...
- 5分钟完全掌握Python协程
本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理 1. 协程相关的概念 1.1 进程和线程 进程(Process)是应用程序启动的实例,拥有代码.数据 ...
- python pip命令的安装与实验安装scrapy
大家在使用python时候,很多时候导入模块都会发现该模块不存在,那么我们就需要下载安装,可是有时候安装会出现各种问题,大家回去请教别人,大部分程序员会回答你:pip install 什么等,可是你p ...
- mssql不存在便插入存在不执行操作
前言 参考:https://www.jb51.cc/mssql/76911.html 在mssql中,在记录不存在时插入记录,如果存在则不执行操作 数据库 相关语句 --创建表 CREATE TABL ...
- SpringBoot整合任务调度框架Quartz及持久化配置
目录 本篇要点 SpringBoot与Quartz单机版快速整合 引入依赖 创建Job 调度器Scheduler绑定 自动配置,这里演示SimpleScheduleBuilder 手动配置,这里演示C ...
- 登录&单点登录介绍
COOKIE & SESSION & TOKEN 主要用来跟踪会话,识别用户所用.cookie 是客户端,session 是服务端的. 因为 http 是无状态协议,每一次的访问都不知 ...