业务程序数据库session 设置多大

业务程序数据库session 设置多大,第1张

session存在服务器端,安全,可存一些复杂的数据,但是占用服务器内存或数据库资源,和页面跳转没有关系,一个用户一个session。

应用场合是不同的,ViewState只限制在当前页面内;Session用于页面间传递。

另外Application Session Cookie ViewState Cache Hidden

Session

1. Session用来保存每一个用户的专有信息

2. Session的生存期是用户持续请求时间加上一段时间(一般是20分钟左右)

3. Session信息是保存在Web服务器内存中的,保存数据量可大可小

4. Session超时或者被关闭将自动释放数据信息

5. 由于用户停止使用应用程序之后它仍在内存中存留一段时间,因此这种方法效率较低

6. 代码:Session[“UserID”]=“test”

String UserName=Session[“UserID”].ToString()

ViewState

1. ViewState用来保存用户的状态信息,有效期等于页面的生命周期

2. 可以保存大量数据但是要慎用,因为会影响程序性能

3. 所有的Web服务器控件都是用ViewState在页面PostBack期间保存状态

4. 不需要则关闭 @page 里面设置EnableViewState=false

5. 代码:ViewState[“ID”]=“yiner”

String ID =ViewState[“ID”].ToString()

Application

1. Application用来保存所有用户共用的信息

2. 在Asp时代,如果要保存的数据在应用程序生存期内不会或者很少发生改变,那么使用Application是理想的选择。但是在Asp.net开发环境中我们把类似的配置数据放在Web.config中。

3. 如果要使用Application 要注意的是所有的写 *** 作都要在Application_OnStart事件中完成(global.Asax),尽管可以使用Application.Lock()避免了冲突,但是它串行化了对Application的请求,会产生严重的性能瓶颈。

4. 不要使用Application保存大数据量信息

5. 代码:Application[“UserID”]=”test”

String UserName=Application[“UserID”].ToString()

Cookie

1. Cookie用来保存客户浏览器请求服务器页面的请求信息

2. 我们可以存放非敏感的用户信息,保存时间可以根据需要设置

3. 如果没有设置Cookie失效日期,它的生命周期保存到关闭浏览器为止

4. Cookie对象的Expires属性设置为MinValue表示永不过期

5. Cookie存储的数据量受限制,大多数的浏览器为4K因此不要存放大数据

6. 由于并非所有的浏览器都支持Cookie,数据将以明文的形式保存在客户端

7. 代码:Response.Cookies[“UserID”]=”test”

String UserName= Resopnse.Cookies [“UserID”].ToString()

Cache

1. Cache用于在Http请求期间保存页面或者数据

2. Cache的使用可以大大的提高整个应用程序的效率

3. 它允许将频繁访问的服务器资源存储在内存中,当用户发出相同的请求后

服务器不是再次处理而是将Cache中保存的数据直接返回给用户

4. 可以看出Cache节省的是时间—服务器处理时间

5. Cache实例是每一个应用程序专有的,其生命周期==该应用程序周期

应用程序重启将重新创建其实例

6. 注意:如果要使用缓存的清理、到期管理、依赖项等功能必须使用Insert 或者Add方法方法添加信息

7. 代码:Cache[“ID”]=“yiner”或者Cache.Insert(“ID”,”test”)

String ID =Cache[“ID”].ToString()

Hidden

1. Hidden控件属于Html类型的服务器控件,始终处于隐藏状态

2. 每一次提交的时候它会和其他服务器控件一起提交到服务器端

3. 代码如下:Hidden.Value=”king”

string id=Hidden.Value要使用Runat=server

由于session值之前没有设置 以至于刚登录的网站 不到一分钟就超时了 总结了一下 原来是session过期的原因 以下是设置session时间的 个方法

在tomcat——>conf——>servler xml文件中定义

<Context path= /test docBase= /test defaultSessionTimeOut= isWARExpanded= true isWARValidated= false isInvokerEnabled= true isWorkDirPersistent= false />defaultSessionTimeOut=

在web xml中定义

<session config><session timeout></session timeout></session config>

在程序中定义

session setMaxInactiveInterval( * )

设置单位为秒 设置为 永不过期

lishixinzhi/Article/program/Java/hx/201311/26519

常用的有两种方法:

1. 在主页面中写入下面两句:

HttpSession session=request.getSession(true)

session.setMaxInactiveInterval(3600)//3600秒,注意服务器端的3600秒,而不是客户端的

2. 在项目的web.xml中设置:

<session-config>

<session-timeout>60</session-timeout>

</session-config>

这里的60就是60分钟。

Session:在计算机中,尤其是在网络应用中,称为“会话控制”。Session 对象存储特定用户会话所需的信息。这样,当用户在应用程序的 Web 页之间跳转时,存储在 Session 对象中的变量将不会丢失,而是在整个用户会话中一直存在下去。当用户请求来自应用程序的 Web 页时,如果该用户还没有会话,则 Web 服务器将自动创建一个 Session 对象。当会话过期或被放弃后,服务器将终止该会话。Session 对象最常见的一个用法就是存储用户的首选项。例如,如果用户指明不喜欢查看图形,就可以将该信息存储在 Session 对象中。有关使用 Session 对象的详细信息,请参阅“ASP 应用程序”部分的“管理会话”。注意 会话状态仅在支持 cookie 的浏览器中保留。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/8135135.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-13
下一篇2023-04-13

发表评论

登录后才能评论

评论列表(0条)

    保存