我正在尝试创建DotNetOpenAuth OpenID MVC 3项目,但无法接收用户身份验证状态。我的post方法工作正常,但当请求返回到HttpGet方法,并且我检查User.Identity.IsAuthenticated状态时,它会在我已成功登录到任何openID提供程序时返回false。MVC 3 - DotNetOpenAuth OpenID未返回经过身份验证的用户
我已经启用了在webconfig dotNetOpenAuth untrustedWebRequest尚未解决的问题本地主机通信,我已经花了几个小时寻找一个答案,为什么用户不被返回一个身份验证的用户。
必须存在一些逻辑错误,导致用户不能从我的代码中验证的openID提供程序返回,但我找不到它。
感谢您对我的问题的任何回应!
我的控制器:
namespace DotNetOpenAuth_OpenID.Controllers
{
public class UserController : Controller
{
private static OpenIdRelyingParty openid = new OpenIdRelyingParty();
public IFormsAuthenticationService FormsService { get; set; }
protected override void Initialize(RequestContext requestContext)
{
if (FormsService == null)
{
FormsService = new AuthenticationService();
}
base.Initialize(requestContext);
}
// **************************************
// URL: /User/LogIn
// **************************************
[HttpGet]
public ActionResult LogIn()
{
if (User.Identity.IsAuthenticated) <===== RETURNS FALSE
{
return RedirectToAction("Profile", "User");
}
Identifier id;
if (Identifier.TryParse(Request.Form["openid_identifier"], out id))
{
try
{
var req = openid.CreateRequest(Request.Form["openid_identifier"]);
return req.RedirectingResponse.AsActionResult();
}
catch (ProtocolException ex)
{
//display error by showing original LogOn view
//this.ErrorDisplay.ShowError("Unable to authenticate: " + ex.Message);
return View("Login");
}
//return LogIn(new User { OpenID = id }, Request.Form["ReturnUrl"]);
}
return View("Login");
}
[HttpPost]
public ActionResult LogIn(User model, string returnUrl)
{
string openID = ModelState.IsValid ? model.OpenID : Request.Form["openid_identifier"];
if (User.Identity.IsAuthenticated)
{
return RedirectToAction("Profile", "User");
}
else if (!string.IsNullOrEmpty(openID))
{
return Authenticate(openID, returnUrl);
}
else if (ModelState.IsValid)
{
ModelState.AddModelError("error", "The OpenID field is required.");
}
// If we got this far, something failed, redisplay form
return View(model);
}
我还发现CodePlex上的Nerd Dinner项目深入到MVC 3&4的许多方面,但也有你可能需要建立一个DotNetOpenAuth openId认证用户界面供客户端登录。在学习代码时你需要付出一些努力,但它确实按照广告的方式工作。 – Shawn