У меня есть Identity Server 4 , настроенный с OpenIdConnect для Azure AD.
Когда пользователь нажимает кнопку входа в систему, IS4 перенаправляет на Azure AD и при обратном вызове на IS4, он показывает эту ошибку:
data:image/s3,"s3://crabby-images/b8197/b8197ad58694bd63f9fba16b6716dfa371a01316" alt="enter image description here"
Вот как я запрашиваю токен у почтальона:
Обратите внимание, что URL обратного вызова является форматом мобильного приложения.
Это моя конфигурация:
services.AddAuthentication()
.AddCookie(options => new CookieAuthenticationOptions
{
ExpireTimeSpan = TimeSpan.FromHours(12),
SlidingExpiration = false,
Cookie = new CookieBuilder
{
Path = "",
Name = "MyCookie"
}
}).AddOpenIdConnect(options =>
{
options.ClientId = configuration["OpenIdConnect:ClientId"];
options.Authority = configuration["OpenIdConnect:Authority"];
options.SignedOutRedirectUri = configuration["OpenIdConnect:PostLogoutRedirectUri"];
options.CallbackPath = configuration["OpenIdConnect:CallbackPath"];
options.ResponseType = OpenIdConnectResponseType.CodeIdToken;
options.Resource = configuration["OpenIdConnect:Resource"];
options.ClientSecret = configuration["OpenIdConnect:ClientSecret"];
options.SaveTokens = true;
options.RequireHttpsMetadata = false;
options.TokenValidationParameters = new TokenValidationParameters
{
NameClaimType = "name",
RoleClaimType = "role"
};
options.SignInScheme = IdentityServerConstants.ExternalCookieAuthenticationScheme;
});
И это мои параметры:
"OpenIdConnect": {
"ClientId": "xxxxxxxxxx",
"Authority": "https://login.microsoftonline.com/xxxxxxxxxx/",
"PostLogoutRedirectUri": "https://uri-of-my-identity-server.azurewebsites.net",
"CallbackPath": "/signin-oidc",
"ResponseType": "code id_token",
"Resource": "https://graph.microsoft.com/",
"ClientSecret": "my-secret"
},
data:image/s3,"s3://crabby-images/5cc1a/5cc1ade3d646218b1fbfae62c02337c7a22fa94b" alt="enter image description here"
Примечание: эта ошибка возникает только в Azure среде (не локально)
Примечание: в приложении Xamarin, когда Azure возвращается к экрану согласия IS4 и показывает это сообщение:
data:image/s3,"s3://crabby-images/4cb62/4cb62c6e6565c9387e60e405d035a873e49b89d2" alt="enter image description here"