2011-05-03 57 views
6

基本上我想要一个用户登录到他们的坚持,他们在下次登录时用户名后设置一个cookie。这里是我的代码设置cookie。一旦cookie被设置,当我在Firefox中查看站点cookie时,它会显示sessionID cookie,但不是我刚刚设置的cookie。当我检查Fiddler中的标题时,我没有看到它设置cookie,只有我的sessionID cookie。ASP.Net MVC Cookie不能坚持

HttpCookie hc = new HttpCookie("username", model.UserName); 
hc.Expires = DateTime.Now.AddYears(1); 
System.Web.HttpContext.Current.Request.Cookies.Add(hc); 

这里是我检查cookie是否存在的地方。

if (System.Web.HttpContext.Current.Request.Cookies["username"] != null) 

这里是方法有问题的完整的上下文

public ActionResult LogOn() 
{ 
    if (System.Web.HttpContext.Current.Request.Cookies["username"] != null) 
     return View(new LogOnModel { UserName = System.Web.HttpContext.Current.Request.Cookies["username"].Value }); 
    else 
     return View(); 
} 

[HttpPost] 
public ActionResult LogOn(LogOnModel model, string returnUrl) 
{ 
    if (ModelState.IsValid) 
    { 
     if (MembershipService.ValidateUser(model.UserName, model.Password)) 
     { 
      HttpCookie hc = new HttpCookie("username", model.UserName); 
      hc.Expires = DateTime.Now.AddYears(1); 
      System.Web.HttpContext.Current.Request.Cookies.Add(hc); 

      FormsService.SignIn(model.UserName, model.RememberMe); 
      if (!String.IsNullOrEmpty(returnUrl)) 
      { 
       return Redirect(returnUrl); 
      } 
      else 
      { 
       return RedirectToAction("Index", "Home"); 
      } 
     } 
     else 
     { 
      ModelState.AddModelError("", "The user name or password provided is incorrect."); 
     } 
    } 

    return View(model); 
} 
+0

你并不需要经过的System.Web。[.. 。]与Request和Response对象一起工作。他们已经被控制器暴露。虽然我怀疑它,但是现在您可能会遇到问题,因为您不在实际的MVC应用程序中。 @亚当的答案应该是你的修复。 – Gup3rSuR4c 2011-05-03 23:14:35

回答

9

添加到response.cookies不Request.Cookies时

+1

+1。丁!那很简单。 – 2011-05-03 23:10:00

+0

太棒了,我知道这是我忽略的简单东西。 – Jhorra 2011-05-03 23:14:57