Я использую @ azure / msal- angular для входа в систему. Я предоставил следующие области «согласования»:
['openid', 'email', 'profile']
Процесс перенаправления входа в систему работает, поскольку он перенаправляет меня на URL-адрес «https://login.microsoftonline.com», а параметр «scope» выглядит вот так:
&scope=email%20openid%20profile
Пока все хорошо, я вхожу в систему, меня перенаправляют обратно на свой сайт, затем я распечатываю метод getUser (), предоставляемый службой MSAL (скрытый в случае чувствительных значений ):
displayableId: "D...Mm"
name: "Mo....as"
identityProvider: "htt...0"
userIdentifier: "OG....5"
idToken:
aud: "ca...20"
iss: "htt....0"
iat: 1..83
nbf: 15..83
exp: 15...83
acct: 0
aio: "42dg....R/XQoA"
auth_time: 159...282
email: "DM.....com"
name: "Mo....as"
nonce: "7bc....d95d"
oid: "8e8f....fc3"
platf: "1"
preferred_username: "DMol....om"
sub: "j0KKHsU....WMEB_H3fyU"
tid: "98f7abd.....6fbd5f9"
uti: "Eu4y.....cMAAA"
ver: "2.0"
Здесь не указано значение UPN. После исследования я обнаружил, что версия 1.0 по умолчанию возвращает UPN.
Я нашел этот полезный вопрос с большим количеством информации, но на самом деле он не отвечает на вопрос:
{ ссылка }
Ниже приведен снимок экрана из документации Microsoft (https://docs.microsoft.com/en-us/azure/active-directory/develop/active-directory-optional-claims)
В нем конкретно указано, что область «profile» должна возвращать значение «upn». Я не знаю, это проблема с пакетом @ azure / msal- angular, потому что URL-адрес для входа создается правильно.