Asp.net Web 状态管理

最近在网上搜罗了 ASP.NET WEB 状态管理方面的一些内容,终于把这些内容整合总结了一下。

1. 希望自己通过整理,能够掌握一些,为自己投资。

2. 以便自己忘记,又要浪费时间搜罗。

3. 希望对园友有帮助,这是一件很开心的事情

4.
希望大侠们看到问题及时帮忙指正,不想误导自己,更不想误导园友,在下不胜感激

不再磨叽,马上上菜








































































































名称

用户

生存时间

数据

位置

优势

劣势

建议

Application

所有用户

应用程序重新启动

没有限制,只被存储一次

服务器,可以存储在数据库

1. 实现简单

2. 整个应用程序作用域(公用)

1. 整个应用程序作用域的范围导致没有与私人空间

2. 服务器挂掉、升级以及关闭可能会导致数据丢失或被破坏

3. 需要占用服务器内存

存储多用户使用但不经常改变且不考虑安全性的全局信息

Cookie

当前用户

一般很短,但是只要用户不删除,可以是数月甚至数年

少量且经常改变的数据

客户端

1. 存储时间可配置

2. 无需服务器资源

3. 简单

4. 数据持久化

1. 数据大小受限

2. 用户可禁用

3. 潜在安全隐患

需要在客户端且不需要考虑安全性的少量数据

QueryString

一个或一组用户

为下一个请求 (可以跨多个请求重复使用)

很小,简单数据

客户端

1. 无需服务器资源

2. 被广泛支持

3. 实现简单

1. 潜在安全隐患

2. 能力有限(被URL长度限制)

通过链接,从一个面发送到另一个页面或者是相同页面,且不需要考虑安全性的少量数据

Session

当前用户

只要用户是在线的,以及在超时时间内(一般是20分钟),支持自失效

没有限制,但是应尽量小,因为每个用户都有自己单独session的存储

服务器

1. 实现简单

2. 可以使用会话管理事件

3. 数据持久化

4. 可在多计算机、多个进程之间使用

5. 弥补Cookie受限

6. 可以自定义和扩展Session

1. 性能问题

需要考虑安全性,存储特定的单独会话的短期信息

Cache

所有用户或者用户子集

根据实际需要可长可短

可很大、也可以很小、也可以很复杂

客户端/服务器

1. 有ASP.NET管理

2. 当内存不足或者超时,将自动清除

3. 可配置

4. 减轻Web Service或者数据库的负担

5. 提高性能

6. 可靠性

1. 同步不及时

2. 扩展性问题

3. 维护成本

用户经常访问但不经常更新的数据

View State

当前用户

一个页面

少量信息,随着页面的回发,数据将会在页面来回发

客户端,以隐藏域的形式存储

1. 无需服务器资源

2. 实现简单

3. 增强全性

1. 性能问题

2. 设备限制

3. 潜在安全隐患

存储少量需要回发给自己的页面信息

Control state

当前用户

一个页面

少量信息,往返于服务器之间的控制使用的状态信息

客户端,默认以隐藏域的形式存储

1. 无需服务器资源

2. 可靠

3. 通用

1. 特定程序依赖性

需要存储少量信息往返于服务器之间的控制使用的状态信息

Hidden Fields

当前用户

一个页面

少量且经常被改变的数据

客户端

1. 无需服务器资源

2. 被广泛支持

3. 实现简单

1. 潜在安全隐患

2. 存储数据简单

3. 性能问题

4. 存储限制

需要发送到另一个页面或者回发,且无需考虑安全性的少量页面信息

Profile Properties

当前用户

配置文件更新

任何类型的数据

服务器

1. 数据持久化

2. 可在多计算机、多个进程之间使用

3. 可扩展性

1. 性能问题

2. 额外的配置要求

3. 维护数据

用户session过期后需要持久化的信息,用户下次访问时需要恢复的信息

Database

当前用户

只要不被删除

任何类型的数据

服务器

1. 安全性

2. 数据存储量大

3. 数据持久化

4. 稳定性和数据完整性

5. 可访问性

6. 被广泛支持

1. 复杂性

2. 性能问题

存储大量的信息,使用管理事务,或者整个应用程序生命周期都需要使用的信息,再次访问时需要使用的信息。考虑数据挖掘,考虑安全性。

再次希望,如果有问题能及时帮忙指正,有问题请留言,有帮助就支持一下吧!

Asp.net Web 状态管理

时间: 2024-12-08 13:18:10

Asp.net Web 状态管理的相关文章

ASP.NET Web – 状态管理

状态类型 客户端或服务器资源 有效时间 ViewState 客户端 只在一个页面中 Cookie 客户端 关闭浏览器时会删除临时cookie,永久cookie存储在客户系统的磁盘上 Session 服务器 会话状态与浏览器相关.会话在超时(默认为20分钟)后变得无效 Application 服务器 在所有的客户端上共享应用程序状态,这个状态在服务器重新启动之前都是有效的 Cache 服务器 类似于应用程序状态,缓存是共享的.但是,使缓存无效有更好的控制方式 客户端的状态管理 -ViewState

ASP.NET Core——状态管理之视图状态

在实际项目中,常常需要保存用户信息来简化掉一些不必要的重复动作,提供人性化和智能的交互方式.然而HTTP协议是无状态的,每个新页面请求都是接.ASP.NET提供了保存状态的不同选项,使得状态额可以在客户端或服务器上保存. 要在客户端保存状态,ASP.NET提供了视图状态.cookie和参数选项.因为安全问题,使用这些状态有一些限制.在服务器端可以使用会话对象.全局应用程序状态.缓存和用户配置文件来保存状态. ASP.NET也提供了一些用于访问状态管理功能的属性.例如,HttpSessionSta

ASP.NET状态管理详解,让你明明白白

开发WinFrom的程序员可能不会在意维护应用程序的状态,因为WinFrom本身就在客户端运行,可以直接在内存中维护其应用程序状态.但ASP.NET应用程序在服务器端运行,客户端使用无状态的http协议对ASP.NET应用程序发出请求,ASP.NET应用程序响应用户请求,向客户端发送请求的HTML代码,服务器并不会维护任何客户端状态.考虑一个有成千上万并发用户的服务器,如果为每一个用户都维护状态的话会耗费非常多的资源. 由于使用无状态的http协议作为web应用程序的通信协议,当客户端每次请求页

[原创]java WEB学习笔记28: 会话与状态管理Cookie 机制

1.会话与状态管理 1)背景 ① HTTP协议是一种无状态的协议,WEB服务器本身不能识别出哪些请求是同一个浏览器发出的 ,浏览器的每一次请求都是完全孤立的: ② 作为 web 服务器,必须能够采用一种机制来唯一地标识一个用户,同时记录该用户的状态: ③ 问题:怎么才能实现网上商店中的购物车呢:某个用户从网站的登录页面登入后,再进入购物页面购物时,负责处理购物请求的服务器程序必须知道处理上一次请求的程序所得到的用户信息. 2)会话和会话状态 ① WEB应用中的会话:指一个客户端浏览器与WEB服务

web应用程序的状态管理

一.Web应用程序状态形式1.表单隐藏字段2.cookie——把用户状态信息通过服务器发送到客户端浏览器中保存3.Session会话跟踪,服务器为客户端创建并维护的用于存放客户状态数据的session对象4.URL地址重写.(一)cookie 1:Cookie原理: 服务器在响应请求时将一些数据以“键-值”对的形式通过响应信息保存在客户端,当浏览器再次访问相同的应用时,会将原先的Cookie通过请求信息带到服务器端. Cookie cookie = new Cookie("cool",

使用ASP.NET MVC和AngularJS的Web模块化管理

快速浏览标题便了解到本文要谈到公开资源平台,该平台允许快速,轻松地创建一个管理网络,并不需要在风格,导航,解决方案架构和其它跟主要任务无关的琐事上花费过多的时间. 平台视觉图和其中一块模板:(见附图一) 很长一段时间里,我们使用WPF技术模块化管理应用.我们做出的决定是将此管理迁移到网站中.最后我们得出了2个不同的产品:第一个:平台,就是这篇文章致力于介绍的,第二个是用于电子商务应用程序开发使用的集合模块. 技术运用于:(见附图二) 我们决定使用这些技术都是我们广泛应用微软产品的经验结果. 我们

[水煮 ASP.NET Web API2 方法论](1-8)添加 Session 状态

问题 ASP.NET Web API 构建 Web 应用程序时,要求使用 Session 在服务器存储一些用户特定的信息 解决方案 ASP.NET Web API 不支持 Session,因为 API 根本不依赖于System.Web.他想试图摆脱伪造 Session,非 HTTP这样的概念. 然而,如果我们 在 ASP.NET 运行时中运行 ASP.NET Web API,还想启用 Session.我们可以通过两种方式来做: 全局:应用于整个 API 局部:应用于指定路由 启用全局方式,我们需

(转)web会话管理方式

阅读目录 1. 基于server端session的管理 2. cookie-based的管理方式 3. token-based的管理方式 4. 安全问题 5. 总结 http是无状态的,一次请求结束,连接断开,下次服务器再收到请求,它就不知道这个请求是哪个用户发过来的.当然它知道是哪个客户端地址发过来的,但是对于我们的应用来说,我们是靠用户来管理,而不是靠客户端.所以对我们的应用而言,它是需要有状态管理的,以便服务端能够准确的知道http请求是哪个用户发起的,从而判断他是否有权限继续这个请求.这

ASP.NET Web API 2基于令牌的身份验证

基于令牌的认证 我们知道WEB网站的身份验证一般通过session或者cookie完成的,登录成功后客户端发送的任何请求都带上cookie,服务端根据客户端发送来的cookie来识别用户. WEB API使用这样的方法不是很适合,于是就有了基于令牌的认证,使用令牌认证有几个好处:可扩展性.松散耦合.移动终端调用比较简单等等,别人都用上了,你还有理由不用吗? 下面我们花个20分钟的时间来实现一个简单的WEB API token认证: Step 1: 新建一个空的WEB API项目,项目名称就设置为