ASP.NET MVC一共包括ViewData、ViewBag、TempData、Session、Cookie和ApplicationState这6个容器,它们为我们提供了不同数据所需的便捷,做这个总结之前是因为碰到跨服务器之间的做了负载均衡后的验证问题,当登录后台操作的时候会自动登出,当时感觉就是在相同的域名下服务器切换到另外一台了,所以把相关的内容总结到下面这个表格中:
[ Session]
使用方式和[ TempData]很像,都是通过Key/Value来存放数据
[ Cookie]
[ Application]
因为[ Application]所存放的信息是为了储存整个Server中的信息,例如系统参数、或是拜访人数,在MVC中也可以在Global中
特性 | ViewData | TempData | Session | Cookie | Application |
生命周期 | 短,只存在一个 Action | 短,存在1次的 Request | 长,预设为20分钟,可以调整 | 长,预设为直到浏览器关闭为止,可以调整 | 长,直到应用程序结束或重启 |
储存端 | Server | Server | Server | Client | Server |
跨多台Server | 无,因为其无需跨多台Server | 因为是设定在Sesstion,所以看Session的设定 | 预设是无法跨多台Server,但可以改成存放在SQL Server | 可以设定Cookie的Domain,让同个Domain的Server共同使用 | 无 |
使用者共享性 | 无 | 无 | 无 | 无 | 有 |
使用时机 | 从 Controller 传递小量数据到 Action 时使用 | 当数据需暂时存放,而在下次进入页面时读取出来使用 | 存放每个用户的特殊信息,EX:限制使用者登入时间,若逾时则需重新登入 | 记录在Client端,可存放用户个人的喜好信息 | 存放例如权限设定、访客人数 |
[ Session]
使用方式和[ TempData]很像,都是通过Key/Value来存放数据
Session["UserName"] = User.Identity.Name;
[ Cookie]
// Set Cookie
HttpCookie Cookie = new HttpCookie("User", "admin");
Cookie.Expires = DateTime.Now.AddDays(1); //设置Cookie到期时间
HttpContext.Response.Cookies.Add(Cookie);
// Get Cookie
string User = Request.Cookies["User"].ToString();
[ Application]
因为[ Application]所存放的信息是为了储存整个Server中的信息,例如系统参数、或是拜访人数,在MVC中也可以在Global中
protected void Application_Start()
{
Application["Visit"] = 0;
}
而需要读取[
Application]只需通过HttpContext.Application来读取参数或是设置参数,如下:
HttpContext.Application["Visit"] = int.Parse(HttpContext.Application["Visit"].ToString()) + 1