[玩转系统] 从 PowerShell 调用 Azure 函数
作者:精品下载站 日期:2024-12-14 07:13:54 浏览:14 分类:玩电脑
从 PowerShell 调用 Azure 函数
这篇文章是有关 Azure Functions 和 PowerShell 的系列文章的一部分。查看该系列中其他帖子的列表!
到目前为止,我们已经设置了一个 Azure Function 应用程序,并使用 Azure Active Directory 配置了身份验证和授权。现在,只要我们期望用户使用浏览器点击我们的功能,一切就可以了。我经常使用函数来构建由代码调用的 API。就我而言,代码通常是 PowerShell 脚本,但我们暂时将代码称为应用程序。
注册调用 api 的客户端应用程序
由于在这种情况下我们的应用程序在客户端计算机上运行,因此我们不能依赖应用程序的身份,因为这需要应用程序具有某种秘密(密码或证书),并且必须嵌入该秘密代码中,我们的应用程序的用户可以提取该代码。一如既往,代码中没有秘密!
这也意味着我们不能依赖 Azure AD 将令牌发送到 RedirectURI 中指定的公共终结点,因为我们的客户端很可能不会暴露在 Internet 上。
为了解决这个问题,有一种叫做公共客户端的东西。基本上,我们注册的所有应用程序都可以设置为充当客户端(如果它们要调用其他服务)。用于 Web 服务器和 API 的常规应用程序称为机密客户端,因为它们的代码在受控环境中运行,我们可以安全地提供秘密(密码或证书)。桌面应用程序和脚本无法安全地存储秘密,这使得它们成为公共客户端类别的一部分。
在我们的例子中,我们需要一个使用本机客户端方法设置的应用程序(或应用程序注册)。本机客户端只是桌面应用程序或脚本等应用程序的另一种说法。现在我们可以将此配置添加到当前的应用程序中,但为了使事情更加干净和分离,我将介绍如何创建单独的客户端应用程序。
让我们看一个应用程序注册示例!
和以前一样,我将从 PowerShell 运行 Azure CLI。我们将需要我们之前创建的服务器应用程序的应用程序 ID(也称为 clientId)。这次我们将重定向 uri 设置为 http://localhost
。
通过服务器应用程序的 ID,我们可以从应用程序获取所有 oauth2Permissions,并使用权限 user_impersonation
授予客户端应用程序以用户身份登录服务器应用程序的权限。
创建应用程序后,我们需要将 requestsAccessTokenVersion 设置为 2,就像我们对服务器应用程序所做的那样。这告诉 Azure AD 我们需要版本 2 令牌,这是我们需要的,因为我们在应用服务上设置高级模式身份验证时在颁发者末尾指定了 v2.0。
$ClientAppDisplayName = 'MySuperApiClient'
$ServerAppId = 'c491d3f8-0d15-4ea5-96fd-957601d579fa'
$RedirectUri = 'https://localhost'
# Get the server app
$ServerApp = az ad app show --id $ServerAppId | ConvertFrom-Json
# Get oAuthPermission for user_impersonation from server app
$oAuthPermissionId = az ad app show --id $ServerApp.AppId --query "oauth2Permissions[?value=='user_impersonation'].id" -o tsv
# Build part of a manifest for requiredResourceAccess
$requiredResourceAccess = @{
resourceAppId = $ServerApp.AppId
resourceAccess = @(
@{
id = $oAuthPermissionId
type = 'Scope'
}
)
} | ConvertTo-Json -AsArray -Depth 4 -Compress | ConvertTo-Json
# Pipe to ConvertTo-Json twice to escape all quotes, or az cli will remove them when parsing
# Register client application
$ClientApp = az ad app create --display-name $ClientAppDisplayName --native-app --reply-urls $RedirectUri --required-resource-accesses $requiredResourceAccess | ConvertFrom-Json
# Create a service principal for the application
$null = az ad sp create --id $ClientApp.appId | ConvertFrom-Json
# Consent the application for all users
$null = az ad app permission grant --id $ClientApp.AppId --api $ServerApp.AppId
# Disable implicit flow, we don't need this for authcode or device code flows
$null = az ad app update --id $ClientApp.AppId --set oauth2AllowIdTokenImplicitFlow=false *>&1
# Set application to use V2 access tokens
$Body = @{
api = @{
requestedAccessTokenVersion = 2
}
} | ConvertTo-Json -Compress | ConvertTo-Json
# Pipe to ConvertTo-Json twice to escape all quotes, or az cli will remove them when parsing
$null = az rest --method PATCH --uri "https://graph.microsoft.com/v1.0/applications/$($ClientApp.objectId)" --body $Body --headers "Content-Type=application/json"
# Output the ClientId for use later
Write-Output $ClientApp.AppId
现在我们需要将客户端应用程序设置为要求为用户分配角色,就像我们为服务器应用程序所做的那样。
$ClientAppId = '479fe3c1-a9a4-4098-b343-db98e7c6e81b'
az ad sp update --id $ClientAppId --set appRoleAssignmentRequired=true
我们可以再次为用户分配默认访问角色,就像我们对上面的服务器应用程序所做的那样,这次使用我们的客户端 appId 而不是服务器。
$AppId = '479fe3c1-a9a4-4098-b343-db98e7c6e81b'
$UserPrincipalName = '[email '
$App = az ad sp show --id $AppId | ConvertFrom-Json
$principalId = az ad user show --id $UserPrincipalName --query 'objectId' -o tsv
$Body = @{
appRoleId = [Guid]::Empty.Guid
principalId = $principalId
resourceId = $App.objectId
} | ConvertTo-Json -Compress | ConvertTo-Json
az rest --method post --uri "https://graph.microsoft.com/v1.0/users/$UserPrincipalName/appRoleAssignments" --body $Body --headers "Content-Type=application/json"
就是这样!现在我们有一个服务器和一个客户端应用程序,我们将它们设置为要求为用户分配角色。获得对服务器应用程序的访问权限将允许用户使用浏览器浏览服务器,授予对客户端应用程序的访问权限将允许用户使用客户端应用程序访问服务器。
现在,我们当然可以通过简单地将本机客户端平台添加到我们的服务器应用程序中,将这些应用程序合并为一个,如果您使用 Azure Functions 构建 API,这可能是更好的方法,但我选择在我的例子涵盖了双方,有时我们只需要设置一个服务器应用程序,有时我们只需要设置一个客户端应用程序,有时客户端应用程序需要多个API的权限。
让我们快速讨论一下这篇相当长的文章的最后部分。如何使用 PowerShell 访问我的 API?
使用 PowerShell 从 AzureAD 获取 OAuth 令牌
有多种方法可以从 Azure AD 获取 oauth 令牌。这次我将使用 PowerShell 模块 MSAL.PS。 MSAL.PS 是 dotnet 的 MSAL 客户端库的包装器,它包含我们需要的所有内容,可供使用!
首先安装模块。
Install-Module MSAL.PS
现在我们需要请求令牌的应用程序的 clientID、租户的租户 ID 以及范围列表。重定向 URI 需要与我们的应用程序上配置的重定向 URI 匹配。
$ClientAppId = '479fe3c1-a9a4-4098-b343-db98e7c6e81b'
$TenantId = "b5fbba89-c11c-4ba3-baf3-67fb6d5fb61f"
$Scopes = 'https://mysuperapi.azurewebsites.net/user_impersonation'
$RedirectUri = 'http://localhost'
Import-Module 'MSAL.PS' -ErrorAction 'Stop'
$PublicClient = [Microsoft.Identity.Client.PublicClientApplicationBuilder]::Create($ClientAppId).WithRedirectUri($RedirectUri).Build()
$token = Get-MsalToken -PublicClientApplication $PublicClient -TenantId $TenantId -Scopes $Scopes
Invoke-RestMethod -Uri "https://mysuperapi.azurewebsites.net/api/mysuperfunc" -Headers @{Authorization = "Bearer $($token.AccessToken)" }
猜你还喜欢
- 03-30 [玩转系统] 如何用批处理实现关机,注销,重启和锁定计算机
- 02-14 [系统故障] Win10下报错:该文件没有与之关联的应用来执行该操作
- 01-07 [系统问题] Win10--解决锁屏后会断网的问题
- 01-02 [系统技巧] Windows系统如何关闭防火墙保姆式教程,超详细
- 12-15 [玩转系统] 如何在 Windows 10 和 11 上允许多个 RDP 会话
- 12-15 [玩转系统] 查找 Exchange/Microsoft 365 中不活动(未使用)的通讯组列表
- 12-15 [玩转系统] 如何在 Windows 上安装远程服务器管理工具 (RSAT)
- 12-15 [玩转系统] 如何在 Windows 上重置组策略设置
- 12-15 [玩转系统] 如何获取计算机上的本地管理员列表?
- 12-15 [玩转系统] 在 Visual Studio Code 中连接到 MS SQL Server 数据库
- 12-15 [玩转系统] 如何降级 Windows Server 版本或许可证
- 12-15 [玩转系统] 如何允许非管理员用户在 Windows 中启动/停止服务
取消回复欢迎 你 发表评论:
- 精品推荐!
-
- 最新文章
- 热门文章
- 热评文章
[影视] 黑道中人 Alto Knights(2025)剧情 犯罪 历史 电影
[古装剧] [七侠五义][全75集][WEB-MP4/76G][国语无字][1080P][焦恩俊经典]
[实用软件] 虚拟手机号 电话 验证码 注册
[电视剧] 安眠书店/你 第五季 You Season 5 (2025) 【全10集】
[电视剧] 棋士(2025) 4K 1080P【全22集】悬疑 犯罪 王宝强 陈明昊
[软件合集] 25年6月5日 精选软件22个
[软件合集] 25年6月4日 精选软件36个
[短剧] 2025年06月04日 精选+付费短剧推荐33部
[短剧] 2025年06月03日 精选+付费短剧推荐25部
[软件合集] 25年6月3日 精选软件44个
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电视剧] 欢乐颂.5部全 (2016-2024)
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[影视] 【稀有资源】香港老片 艺坛照妖镜之96应召名册 (1996)
[剧集] 神经风云(2023)(完结).4K
[剧集] [BT] [TVB] [黑夜彩虹(2003)] [全21集] [粤语中字] [TV-RMVB]
[实用软件] 虚拟手机号 电话 验证码 注册
[资源] B站充电视频合集,包含多位重量级up主,全是大佬真金白银买来的~【99GB】
[影视] 内地绝版高清录像带 [mpg]
[书籍] 古今奇书禁书三教九流资料大合集 猎奇必备珍藏资源PDF版 1.14G
[电视剧] [突围] [45集全] [WEB-MP4/每集1.5GB] [国语/内嵌中文字幕] [4K-2160P] [无水印]
[剧集] [央视][笑傲江湖][2001][DVD-RMVB][高清][40集全]李亚鹏、许晴、苗乙乙
[电影] 美国队长4 4K原盘REMUX 杜比视界 内封简繁英双语字幕 49G
[电影] 死神来了(1-6)大合集!
[软件合集] 25年05月13日 精选软件16个
[精品软件] 25年05月15日 精选软件18个
[绝版资源] 南与北 第1-2季 合集 North and South (1985) /美国/豆瓣: 8.8[1080P][中文字幕]
[软件] 25年05月14日 精选软件57个
[短剧] 2025年05月14日 精选+付费短剧推荐39部
[短剧] 2025年05月15日 精选+付费短剧推荐36部
- 最新评论
-
- 热门tag