开始使用适用于.NET的Azure Key Vault密钥客户端库。 Azure Key Vault是一种云服务,它为加密密钥提供安全存储。 可以安全地存储加密密钥、密码、证书和其他机密。 可以通过Azure门户创建和管理Azure密钥保管库。 本快速入门介绍如何使用.NET密钥客户端库从Azure密钥保管库创建、检索和删除密钥
Key Vault密钥客户端库资源:
有关Key Vault和密钥的详细信息,请参阅:
先决条件
- Azure订阅 - 创建试用订阅
- .NET 6 SDK 或更高版本
- Azure CLI
- Key Vault - 可以使用 Azure 门户、Azure CLI 或 Azure PowerShell 创建一个。
本快速入门使用 dotnet 和 Azure CLI
设置
本快速入门使用Azure身份库和Azure CLI对用户进行身份验证,以便访问Azure服务。 开发人员还可以使用Visual Studio或Visual Studio Code对其调用进行身份验证,有关详细信息,请参阅 使用 Azure标识客户端库对客户端进行身份验证。
登录到 Azure
运行
login命令。az login如果 CLI 可以打开默认浏览器,它将执行此操作并加载Azure登录页。
否则,请在 https://aka.ms/deviceloginchina 处打开浏览器页,然后输入终端中显示的授权代码。
在浏览器中使用帐户凭据登录。
授予对 Key Vault 的访问权限
若要通过 Role-Based Access Control (RBAC)获取密钥保管库的权限,请使用 Azure CLI 命令az 角色分配创建为“用户主体名称”(UPN)分配角色。
az role assignment create --role "Key Vault Crypto Officer" --assignee "<upn>" --scope "/subscriptions/<subscription-id>/resourceGroups/<resource-group-name>/providers/Microsoft.KeyVault/vaults/<your-unique-keyvault-name>"
将 <upn>、<subscription-id>、<resource-group-name> 和 <your-unique-keyvault-name> 替换为你的实际值。 你的 UPN 通常采用电子邮件地址格式(例如 username@domain.com)。
创建新的.NET控制台应用
在命令外壳中,运行以下命令以创建名为
key-vault-console-app的项目:dotnet new console --name key-vault-console-app切换到新创建的 key-vault-console-app 目录,然后运行以下命令来生成项目:
dotnet build生成输出不应包含警告或错误。
Build succeeded. 0 Warning(s) 0 Error(s)
安装这些软件包
在命令行界面中,安装用于.NET的Azure Key Vault密钥客户端库:
dotnet add package Azure.Security.KeyVault.Keys
对于本快速入门,还需要安装Azure标识客户端库:
dotnet add package Azure.Identity
设置环境变量
此应用程序使用 Key Vault 名称作为名为 KEY_VAULT_NAME 的环境变量。
Windows
set KEY_VAULT_NAME=<vault-name>
Windows PowerShell
$Env:KEY_VAULT_NAME="<vault-name>"
macOS 或 Linux
export KEY_VAULT_NAME=<vault-name>
对象模型
.NET的 Azure Key Vault 密钥客户端库允许管理密钥。 代码示例部分介绍了如何创建客户端,以及如何设置、检索和删除密钥。
代码示例
添加指令
在 Program.cs 的顶部添加以下指令:
using System;
using Azure.Identity;
using Azure.Security.KeyVault.Keys;
进行身份验证并创建客户端
对大多数Azure服务的应用程序请求必须获得授权。 建议在代码中使用由 Azure Identity 客户端库 提供的 DefaultAzureCredential 类来实现与 Azure 服务的无密码连接。
DefaultAzureCredential 支持多种身份验证方法,并确定应在运行时使用哪种方法。 通过这种方法,你的应用可在不同环境(本地与生产)中使用不同的身份验证方法,而无需实现特定于环境的代码。
在本快速入门中,DefaultAzureCredential使用登录到Azure CLI的本地开发用户的凭据向密钥保管库进行身份验证。 将应用程序部署到Azure时,同一DefaultAzureCredential代码可以自动发现和使用分配给应用服务、虚拟机或其他服务的托管标识。 有关详细信息,请参阅托管标识概述。
在此示例中,密钥保管库的名称扩展为密钥保管库 URI,格式为 https://<your-key-vault-name>.vault.azure.cn。 有关向密钥保管库进行身份验证的详细信息,请参阅开发人员指南。
var keyVaultName = Environment.GetEnvironmentVariable("KEY_VAULT_NAME");
var kvUri = $"https://{keyVaultName}.vault.azure.cn";
var client = new KeyClient(new Uri(kvUri), new DefaultAzureCredential());
保存密钥
对于此任务,请使用 CreateKeyAsync 方法。 该方法的参数接受密钥名和密钥类型。
var key = await client.CreateKeyAsync("myKey", KeyType.Rsa);
注意
如果密钥名已存在,则此代码将创建该密钥的新版本。
检索密钥
现在,可以使用 GetKeyAsync 方法检索以前创建的密钥。
var key = await client.GetKeyAsync("myKey");
删除密钥
最后,让我们使用 StartDeleteKeyAsync 和 PurgeDeletedKeyAsync 方法从密钥保管库中删除并清除密钥。
var operation = await client.StartDeleteKeyAsync("myKey");
// You only need to wait for completion if you want to purge or recover the key.
await operation.WaitForCompletionAsync();
var key = operation.Value;
await client.PurgeDeletedKeyAsync("myKey");
示例代码
通过完成以下步骤,修改.NET控制台应用以与Key Vault交互:
将 Program.cs 中的代码替换为以下代码:
using System; using System.Threading.Tasks; using Azure.Identity; using Azure.Security.KeyVault.Keys; namespace key_vault_console_app { class Program { static async Task Main(string[] args) { const string keyName = "myKey"; var keyVaultName = Environment.GetEnvironmentVariable("KEY_VAULT_NAME"); var kvUri = $"https://{keyVaultName}.vault.azure.cn"; var client = new KeyClient(new Uri(kvUri), new DefaultAzureCredential()); Console.Write($"Creating a key in {keyVaultName} called '{keyName}' ..."); var createdKey = await client.CreateKeyAsync(keyName, KeyType.Rsa); Console.WriteLine("done."); Console.WriteLine($"Retrieving your key from {keyVaultName}."); var key = await client.GetKeyAsync(keyName); Console.WriteLine($"Your key version is '{key.Value.Properties.Version}'."); Console.Write($"Deleting your key from {keyVaultName} ..."); var deleteOperation = await client.StartDeleteKeyAsync(keyName); // You only need to wait for completion if you want to purge or recover the key. await deleteOperation.WaitForCompletionAsync(); Console.WriteLine("done."); Console.Write($"Purging your key from {keyVaultName} ..."); await client.PurgeDeletedKeyAsync(keyName); Console.WriteLine(" done."); } } }
测试和验证
执行以下命令以生成项目
dotnet build执行以下命令来运行应用。
dotnet run出现提示时,输入一个密码值。 例如,mySecretPassword。
以下输出的一个变体将会出现:
Creating a key in mykeyvault called 'myKey' ... done. Retrieving your key from mykeyvault. Your key version is '8532359bced24e4bb2525f2d2050738a'. Deleting your key from jl-kv ... done Purging your key from <vault-name> ... done.
后续步骤
在本快速入门中,你创建了一个密钥保管库,存储了一个密钥,然后检索了该密钥。
若要详细了解Key Vault以及如何将其与应用集成,请参阅以下文章:
- 查看 Azure Key Vault 概述
- 阅读密钥概述
- 请参阅应用服务应用程序教程中的 Access Key Vault
- 查看虚拟机教程中的 Access Key Vault
- 请参阅 Azure Key Vault 开发人员指南
- 查看 Key Vault 安全概述
- 查看 特定于密钥的安全最佳做法