Я понимаю, что OpenID - скорее бегемот, или более сложный, чем типичная форма регистрации, но я чувствую, что здесь что-то не хватает.
В соответствии с этим question я должен сохранить уникальный идентификационный ключ, предоставленный моим провайдером.
Поставщик предоставит вам уникальный идентификатор для каждого пользователя - вам это нужно сохранить. Это то, как вы будете соответствовать пользователю, который только что вошел в систему с запись в вашей базе данных.
В мой код (взятый из части MVC), этот уникальный идентификатор указан внутри коммутатора в методе действия LogOn()
:
public ActionResult LogOn()
{
var openid = new OpenIdRelyingParty();
IAuthenticationResponse response = openid.GetResponse();
if (response != null)
{
switch (response.Status)
{
case AuthenticationStatus.Authenticated:
FormsAuthentication.RedirectFromLoginPage(
response.ClaimedIdentifier, false); // <-------- ID HERE! "response.ClaimedIdentifier"
break;
case AuthenticationStatus.Canceled:
ModelState.AddModelError("loginIdentifier",
"Login was cancelled at the provider");
break;
case AuthenticationStatus.Failed:
ModelState.AddModelError("loginIdentifier",
"Login failed using the provided OpenID identifier");
break;
}
}
return View();
}
[HttpPost]
public ActionResult LogOn(string loginIdentifier)
{
if (!Identifier.IsValid(loginIdentifier))
{
ModelState.AddModelError("loginIdentifier",
"The specified login identifier is invalid");
return View();
}
else
{
var openid = new OpenIdRelyingParty();
IAuthenticationRequest request = openid.CreateRequest(Identifier.Parse(loginIdentifier));
// Require some additional data
request.AddExtension(new ClaimsRequest
{
BirthDate = DemandLevel.NoRequest,
Email = DemandLevel.Require,
FullName = DemandLevel.Require
});
return request.RedirectingResponse.AsActionResult();
}
}
Я использую этот идентификатор для FormsAuthentication.SetAuthCookie(IDHERE, true);
?
Что делать, если я хочу также сохранить информацию о пользователях, такую как электронная почта, имя, псевдоним или что-то еще. Как получить этот сбор данных от полагающейся стороны? Если этот процесс зависит от поставщика, которого я использую, я использую провайдер Steam OpenID:
http://steamcommunity.com/openid http://steamcommunity.com/dev