断言签名验证失败

Posted

技术标签:

【中文标题】断言签名验证失败【英文标题】:Assertion failed signature validation 【发布时间】:2021-10-12 21:40:00 【问题描述】:

我收到以下代码错误: var authResult = 等待 authContext.AcquireTokenAsync(Url, appCred, 新用户断言(accessToken));

授权码

var clientID = ConfigurationManager.AppSettings["ClientID"];
                var clientSecret = ConfigurationManager.AppSettings["ClientSecret"];
                var tenant = ConfigurationManager.AppSettings["Tenant"];

                var appCred = new ClientCredential(clientID, clientSecret);
                
                var authContext = new AuthenticationContext(
                    "https://login.microsoftonline.com/" + tenant);
                
var authResult = await authContext.AcquireTokenAsync(Url, appCred,
                    new UserAssertion(accessToken));

错误:

。 [原因 - 提供的签名值与预期的签名值不匹配。,客户端使用的密钥指纹:'', 找到键 'Start=**'] 跟踪 ID:603df266-b9b4-4b27-8216-effc8b879a01 相关 ID:9a7990ea-41ae-47a0-97da-ceb7cb07ecf0 时间戳:2021-08-09 06:46:28Z 在 Microsoft.IdentityModel.Clients.ActiveDirectory.AdalHttpClient.d__211.MoveNext() --- End of stack trace from previous location where exception was thrown --- at System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task) at Microsoft.IdentityModel.Clients.ActiveDirectory.AdalHttpClient.<GetResponseAsync>d__201.MoveNext() --- 从之前抛出异常的位置结束堆栈跟踪 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务) 在 Microsoft.IdentityModel.Clients.ActiveDirectory.AcquireTokenHandlerBase.d__67.MoveNext() --- 从之前抛出异常的位置结束堆栈跟踪 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务) 在 Microsoft.IdentityModel.Clients.ActiveDirectory.AcquireTokenHandlerBase.d__64.MoveNext() --- 从之前抛出异常的位置结束堆栈跟踪 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务) 在 Microsoft.IdentityModel.Clients.ActiveDirectory.AcquireTokenOnBehalfHandler.d__2.MoveNext() --- 从之前抛出异常的位置结束堆栈跟踪 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务) 在 Microsoft.IdentityModel.Clients.ActiveDirectory.AcquireTokenHandlerBase.d__55.MoveNext() --- 从之前抛出异常的位置结束堆栈跟踪 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务) 在 Microsoft.IdentityModel.Clients.ActiveDirectory.AuthenticationContext.d__50.MoveNext() --- 从之前抛出异常的位置结束堆栈跟踪 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务) 在 Microsoft.IdentityModel.Clients.ActiveDirectory.AuthenticationContext.d__35.MoveNext() --- 从之前抛出异常的位置结束堆栈跟踪 --- 在 System.Runtime.ExceptionServices.ExceptionDispatchInfo.Throw() 在 System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(任务任务) 在 .ServicesController.cs:line 378 中的 SpoWebApi.Controllers.AlbathaServicesController.d__13.MoveNext() Microsoft.IdentityModel.Clients.ActiveDirectory

【问题讨论】:

请分享您的完整令牌或授权请求代码。 请找到更新后的问题 您是否尝试过任何官方示例,如果是,请同时参考 @MdFaridUddinKiron,不,这是现有代码。 azure 中的客户端机密已过期。创建新秘密后,我收到此错误。 您能否尝试使用具有相同凭据的post man 获取令牌,如果您能获得它,那么问题将证明您的凭据很好,因为您的代码看起来没问题所以请测试令牌先上postman 【参考方案1】:

我认为您的代码有一点问题,为了获取令牌,您可以尝试以下方式,这在您的代码中缺少,第一步是获取令牌,但在这里 new UserAssertion(accessToken)); 你正在传递 token 怎么得到这个?

除此之外,如果这部分是为了获取令牌,那么这部分应该如下所示:

        [HttpPost]
        public async Task<IActionResult> GetAccessToken()
        
            // Approach 1
            AuthenticationContext authContext = new AuthenticationContext("https://login.microsoftonline.com/" + "Tenant");
            ClientCredential clientCredential = new ClientCredential("ClientId", "Secret");
            var authResult = await authContext.AcquireTokenAsync("https://graph.microsoft.com", clientCredential); //Your Scope and App Credentials

            // Approach 2
            var clientID = "";
            var clientSecret = "";
            var tenant = "";

            var appCred = new ClientCredential(clientID, clientSecret);

            var authContext = new AuthenticationContext(
                "https://login.microsoftonline.com/" + tenant);

            var authResult = await authContext.AcquireTokenAsync("https://graph.microsoft.com", appCred);


            return Ok();
        

如您所见,我按预期获得了令牌。你可以参考这个official document here

希望它会有所帮助。

【讨论】:

我有通过标头传递的令牌。然后我在上面提到的代码中验证这个令牌。 在这种情况下,请分享您的完整代码。这样我们就可以复制了。

以上是关于断言签名验证失败的主要内容,如果未能解决你的问题,请参考以下文章

签名验证失败。没有提供安全密钥来验证签名

Spring Security SAML - 无法验证签名

JwtSecurityTokenHandler ValidateToken:“签名验证失败。没有提供安全密钥来验证签名”

数字签名/电子签名验证失败

为啥 JWS 签名的验证失败?

Javascript(椭圆)上的 ECDSA 签名验证失败 [关闭]