Azure Key Vault 证书:找不到密钥

sup*_*nja 3 azure x509certificate azure-keyvault asp.net-core

我正在尝试为现有 API 启用 Azure Key Vault 证书。我们在 Azure Key Vault 帐户中已拥有机密和 Azure Key Vault 证书。这是配置证书的代码:

 public static IWebHost BuildWebHost() =>
               WebHost.CreateDefaultBuilder()
                   .ConfigureAppConfiguration((context, config) =>
                   {
                       var env = context.HostingEnvironment;
                       config.SetBasePath(Directory.GetCurrentDirectory())
                            .AddJsonFile("appsettings.json", optional: false, reloadOnChange: true);

                       var builtConfig = config.Build();
                       X509Store store = new X509Store(StoreName.My, StoreLocation.CurrentUser);
                       store.Open(OpenFlags.ReadOnly);
                       var cert = store.Certificates.Find(X509FindType.FindByThumbprint, builtConfig["AzureKeyVault:CertThumbprint"], false);
                       config.AddAzureKeyVault(
                               $"https://{builtConfig["AzureKeyVault:Vault"]}.vault.azure.net/",
                               builtConfig["AzureKeyVault:ClientId"],
                               cert.OfType<X509Certificate2>().Single());
                       store.Close();
                   })
                   .UseStartup<Startup>()
                   .Build();
Run Code Online (Sandbox Code Playgroud)

在我的本地计算机上,我正确导入了证书,其中包括下载 pfx 格式。

但我收到的错误消息是:

Microsoft.IdentityModel.Clients.ActiveDirectory.AdalServiceException:'AADSTS700027:客户端断言包含无效签名。[原因 - 未找到密钥。客户端使用的密钥指纹:'xxx'

有什么原因导致这个吗?

Dan*_*con 5

该消息表明证书未使用私钥 ( certmgr.msc) 导入,或者未为请求用户设置权限(使用机器存储时 - certlm.msc