Подтвердить что ты не робот

Использование Cookie в Asp.Net Mvc 4

У меня есть веб-приложение в Asp.Net MVC4, и я хочу использовать cookie для входа пользователя и выхода из системы. Итак, мои действия следующие:

Действие входа

    [HttpPost]
    public ActionResult Login(string username, string pass)
    {
        if (ModelState.IsValid)
        {
            var newUser = _userRepository.GetUserByNameAndPassword(username, pass);
            if (newUser != null)
            {
                var json = JsonConvert.SerializeObject(newUser);

                var userCookie = new HttpCookie("user", json);
                userCookie.Expires.AddDays(365);
                HttpContext.Response.Cookies.Add(userCookie);

                return RedirectToActionPermanent("Index");
            }
        }
        return View("UserLog");
    }

Действие LogOut

    public ActionResult UserOut()
    {
        if (Request.Cookies["user"] != null)
        {
            var user = new HttpCookie("user")
                {
                    Expires = DateTime.Now.AddDays(-1),
                    Value = null
                };
            Response.Cookies.Add(user);
        }
        return RedirectToActionPermanent("UserLog");
    }

И я использую этот файл cookie в _Loyout следующим образом:

@using EShop.Core
@using Newtonsoft.Json
@{
   var userInCookie = Request.Cookies["user"];
}
...
  @if (userInCookie != null && userInCookie.Value)
  {
        <li><a href="#">Salam</a></li>
        <li><a href="@Url.Action("UserOut", "Home")">Cıxış</a></li>
  }
  else
  {
        <li><a href="@Url.Action("UserLog", "Home")">Giriş</a></li>
  }

Но когда я нажимаю * Действие UserOut *, это действие происходит впервые, но тогда это не работает. Я поставил точку останова для процесса поиска, но в результате действия UserLog не использует UserOut. Мой вопрос в том, где я использую неправильный способ cookie? Каков наилучший способ использования cookie в Asp.Net Mvc4 для этого сценария?

4b9b3361

Ответ 1

Попробуйте использовать Response.SetCookie(), потому что Response.Cookies.Add() может вызвать добавление нескольких файлов cookie, тогда как SetCookie обновит существующий файл cookie.

Ответ 2

Мы используем Response.SetCookie() для обновления старых файлов cookie и Response.Cookies.Add() используются для добавления новых файлов cookie. Здесь ниже код CompanyId обновляется в старом cookie [OldCookieName].

HttpCookie cookie = Request.Cookies["OldCookieName"];//Get the existing cookie by cookie name.
cookie.Values["CompanyID"] = Convert.ToString(CompanyId);
Response.SetCookie(cookie); //SetCookie() is used for update the cookie.
Response.Cookies.Add(cookie); //The Cookie.Add() used for Add the cookie.

Ответ 3

userCookie.Expires.AddDays(365); 

Эта строка кода ничего не делает. Это эквивалентно:

DateTime temp = userCookie.Expires.AddDays(365); 
//do nothing with temp

Вероятно, вы хотите

userCookie.Expires = DateTime.Now.AddDays(365);