Używam DotNetOpenAuth do integracji OpenID w naszej aplikacji internetowej. Poniższy kod wymaga podania informacji dostawcy.Dlaczego informacje o identyfikatorze openID nie są przekazywane przez protokół?
try
{
var req = openid.CreateRequest(Request.Form["openid_identifier"]);
req.AddExtension(new DotNetOpenAuth.OpenId.Extensions.SimpleRegistration.ClaimsRequest
{
Email = DotNetOpenAuth.OpenId.Extensions.SimpleRegistration.DemandLevel.Require,
FullName = DotNetOpenAuth.OpenId.Extensions.SimpleRegistration.DemandLevel.Require,
Nickname = DotNetOpenAuth.OpenId.Extensions.SimpleRegistration.DemandLevel.Request,
PostalCode = DotNetOpenAuth.OpenId.Extensions.SimpleRegistration.DemandLevel.Request
});
return req.RedirectingResponse.AsActionResult();
}
Z jakiegoś powodu odpowiedź od operatora openID nigdy nie zawiera informacji, których żądam. Poniżej znajduje się kod:
// Stage 3: OpenID Provider sending assertion response
switch (response.Status) {
case AuthenticationStatus.Authenticated:
Session["FriendlyIdentifier"] = response.FriendlyIdentifierForDisplay;
FormsAuthentication.SetAuthCookie(response.ClaimedIdentifier, false);
if (!string.IsNullOrEmpty(returnUrl)) {
return Redirect(returnUrl);
} else {
return RedirectToAction("Index", "Home");
}
Próbowałem: response.ClaimedIdentifier na milion sposobów i nigdy nie ma cennych informacji, że mogę zrobić coś z. Jakieś pomysły?
Cześć Andrew: Bardzo dziękuję. Google oddaje email, Yahoo nie. Doceniam twoją pomoc. – Geo
Yahoo powinno być teraz ... po prostu uaktualnione, aby go wspierać. –