- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的任务是使用来自外部应用程序的 ADFS token 对 API 进行身份验证,因此我创建了两个应用程序,一个是 MVC 应用程序,可以说 它使用 SSO 凭据进行身份验证,另一个是 WEB API 应用程序,可以说 乙 ,所以在这里从 A,我正在使用 A 的 ADFS token 调用 B 的 API,但是,我收到错误消息。有没有人帮我解决这个问题?
以下是应用程序中 WEB API 中的代码 乙
ConfigurationManager<OpenIdConnectConfiguration> configManager =
new ConfigurationManager<OpenIdConnectConfiguration>(openIdConfig, new
OpenIdConnectConfigurationRetriever());
OpenIdConnectConfiguration config =
configManager.GetConfigurationAsync().GetAwaiter().GetResult();
result.EmailId = Claims.FirstOrDefault(claim => claim.Type == "upn").Value;
result.WindowsNTId = Claims.FirstOrDefault(claim => claim.Type == "unique_name").Value;
var utc0 = new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc);
result.TokenCreatedOn = utc0.AddSeconds(Convert.ToInt64((Claims.FirstOrDefault(claim =>
claim.Type == "iat").Value)));
result.TokenExpiresOn = utc0.AddSeconds(Convert.ToInt64((Claims.FirstOrDefault(claim =>
claim.Type == "exp").Value)));
// Use System.IdentityModel.Tokens.Jwt library to validate the token
JwtSecurityTokenHandler tokenHandler = new JwtSecurityTokenHandler();
var tokenValidationParameters = new TokenValidationParameters
{
ValidateIssuerSigningKey = true,
ValidateIssuer = true,
ValidIssuer = config.Issuer,
IssuerSigningKeys = config.SigningKeys,
ValidateAudience = true,
ValidAudience = expectedAudience
};
SecurityToken validatedToken;
try
{
var claimsPrincipal = tokenHandler.ValidateToken(RawData, tokenValidationParameters,
out validatedToken);
}
catch (Exception ex)
{
}
IDX10501: Signature validation failed. Unable to match key:
kid: 'System.String'.
Exceptions caught:System.Text.StringBuilder'.
token: 'System.IdentityModel.Tokens.Jwt.JwtSecurityToken'.
最佳答案
当解码的 key (kid) 不是有效 key (可能是旧 key ,因为证书 key 通常会更改)时,就会发生这种情况。
来自 https://github.com/AzureAD/azure-activedirectory-identitymodel-extensions-for-dotnet/blob/dev/src/Microsoft.IdentityModel.JsonWebTokens/JsonWebTokenHandler.cs
if (kidExists)
{
if (kidMatched)
throw LogHelper.LogExceptionMessage(new SecurityTokenInvalidSignatureException(LogHelper.FormatInvariant(TokenLogMessages.IDX10511, keysAttempted, jwtToken.Kid, exceptionStrings, jwtToken)));
throw LogHelper.LogExceptionMessage(new SecurityTokenSignatureKeyNotFoundException(LogHelper.FormatInvariant(TokenLogMessages.IDX10501, jwtToken.Kid, exceptionStrings, jwtToken)));
}
就我而言,问题的原因是 key 模数中存在空的第一个字节。解决方案是删除第一个空字节。
var configManager = new ConfigurationManager<OpenIdConnectConfiguration>(configFileUrl, new OpenIdConnectConfigurationRetriever());
var openIdConfig = configManager.GetConfigurationAsync().Result; #region workaround for "Error validating identity token : IDX10511"
//The issue you are facing is caused by the null first byte.
//This is contrary to the JWA (https://tools.ietf.org/html/rfc7518#section-6.3.1.1).
//.NET Core will account for the null byte and .NET framework, apparently, won't.
List<SecurityKey> keys = new List<SecurityKey>();
foreach (var key in openIdConfig.SigningKeys)
{
if (key.CryptoProviderFactory.IsSupportedAlgorithm("SHA256"))
{
var modulus = ((RsaSecurityKey)key).Parameters.Modulus;
var exponent = ((RsaSecurityKey)key).Parameters.Exponent;
if (modulus.Length == 257 && modulus[0] == 0)
{
var newModulus = new byte[256];
Array.Copy(modulus, 1, newModulus, 0, 256);
modulus = newModulus;
}
RSAParameters rsaParams = new RSAParameters();
rsaParams.Modulus = modulus;
rsaParams.Exponent = exponent;
keys.Add(new RsaSecurityKey(rsaParams));
}
else
{
keys.Add(key);
}
}
#endregion
TokenValidationParameters validationParameters =
new TokenValidationParameters
{
// Validate the JWT Issuer (iss) claim
ValidateIssuer = true,
ValidIssuer = issuer,
//// Validate the JWT Audience (aud) claim
ValidateAudience = true,
ValidAudience = audience,
ValidateIssuerSigningKey = true,
IssuerSigningKeys = keys,
RequireExpirationTime = true,
ValidateLifetime = true,
RequireSignedTokens = true,
};
// Now validate the token. If the token is not valid for any reason, an exception will be thrown by the method
SecurityToken validatedToken;
JwtSecurityTokenHandler handler = new JwtSecurityTokenHandler();
var claimsPrincipal = handler.ValidateToken(idToken, validationParameters, out validatedToken);
关于oauth-2.0 - IDX10501 : Signature validation failed. 无法匹配 key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61006792/
假设数组中的所有元素的值都不同于 undefined , null或0 ,是 if (idx < arr.length)相当于if (arr[idx]) ? 最佳答案 没有。 还有其他falsy if
假设数组中的所有元素的值都不同于 undefined , null或0 ,是 if (idx < arr.length)相当于if (arr[idx]) ? 最佳答案 没有。 还有其他falsy if
我试图使用 selenium 下载文件,例如: ftp://ftp.sec.gov/edgar/full-index/1993/QTR1/form.idx ftp://ftp.sec.gov/edga
似乎普遍认为使用 np.take 比数组索引要快得多。例如http://wesmckinney.com/blog/numpy-indexing-peculiarities/ , Fast numpy
对于挑战,a fellow code golfer wrote the following code : import java.util.*; public class Main { publi
这个问题在这里已经有了答案: Iterate over defined elements of a JS array (7 个答案) 关闭 3 年前。 我是编码新手,这种情况对我来说是个大问题。我正
我正在尝试执行 postgresql 查询,但出现语法错误。查询是: c.execute("CREATE TABLE smaller_coverage " "AS (SELECT dono
我读了这个here ,我正在创建一个房地产网站。我熟悉 PHP 和 MySQL,也准备好编写脚本,但真的找不到任何开始。我想编写一个 PHP 脚本,通过来自他的 MLS 公司的 FTP Zip 文件每
特征 RandomAccessIterator 定义了以下函数: fn idx(&mut self, index: uint) -> Option; 由于 self 是可变的,我希望调用 idx()
(在我开始之前,让我们假设这是一个面试问题,我的目的是避免仅仅调用 sorted。) 我有这段有效的 Python 代码: def merge_sorted_lists(left, right):
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭去年。 Im
我有一个用 delphi 编写的应用程序,它是最近的,在 win32 上运行我想用 odbc 连接到数据库,但我不确定要使用哪个数据库驱动程序 数据库所在的目录有.dat.idx每个表的文件 它是一个
我正在编写一些代码,以在 24 小时内每分钟创建并运行 18000 个测试,并将结果存储在我可以做到的 .dat 文件中。 我的下一个任务是在每小时开始时获取时间戳、设备 ID 和随机测试 ID 并将
我正在 MySql Workbench 上工作,每次重命名表/列时,现有的 FK 和 IDX 名称都不会更改。我最终得到了一个所有 FK/IDX 名称都困惑的模型。有没有办法根据新的表和列名称重新生成
我正在 requests.get() 获取一些 json。之后,我想将数据插入到 postgresql 中。发生了一些非常有趣的事情,如果我使用 df.to_sql(index=False),数据毫无
在 Rust 1.14 中,Index trait定义如下: pub trait Index where Idx: ?Sized { type Output: ?Sized; fn i
我正在为一个主要网站实现 WCAG 可访问性报告。可以预见,反复出现的问题之一是表单中的标签。 直到现在,我一直认为将表单标签与其元素相关联的正确方法是在标签的表单属性中使用输入元素的名称,如下所示:
Node.js puppeteer - 下载并打开 .idx 文件 我正在使用 node.js 和 puppeteer 来获取一些数据。我可以单击/下载 .idx 文件...但是如何打开它并处理数据?
我正在运行一个程序: 创建一个ArrayList 在这个数组的顶部添加一些元素 创建一个将减少的“基础”元素 然后使用 for 循环减少基元素并将其添加到数组的顶部(索引 0) 没想到我得到的输出是可
在 Windows Server 2008 上运行的 ASP.NET C# 应用 我发现 Git .idx 和 .pack 文件对编程删除特别有抵抗力: C:\github\my-org\my-rep
我是一名优秀的程序员,十分优秀!