您当前的位置:主页 > 技术探讨 >
session 常用处理
时间:2018-01-19 17:08 日记人:arlen.zhou
1.获取session对象:request.getSession();
2.给session设置值:session.setAttribute("变量名",值对象);
3.获取session中的值:session.getAttribute("变量名");
4.删除session中的值:
session.removeAttribute("变量名");
session.invalidate();//删除所有session中保存的键
5.session的removeAttribute和invalidate方法的区别:
removeAttribute()适用于清空指定的属性。
invalidate()是清除当前session的所有相关信息,是让当前浏览器session销毁,
6.Session优缺点:
Session:会话消息保存在服务器端,基于Cookie实现缺点:会话消息保存在服务器端,安全性较高。
优点:对服务器要求较高。
//获取Session对象
HttpSession session = request.getSession()
session.setAttribute("name","xxx") ;//存值
session.getAttribute("name") ;//取值
7.Session三种销毁原因:
**服务器非正常关闭、Session过期(:默认为20分钟)、invalidate(:session.invalidate();//删除所有session中保存的键 )
8.request.getSession()与request.getSession(true)的区别????
request.getSession()若存在会话则返回该会话,否则返回null
request.getSession(true)如果存在会话则返回该会话,否则新建一个会话
9.session过期时间设置:
Tomcat中Session的默认失效时间为20分钟。
9.1设置方法:
(1)在tomcat下的conf\web.xml中设置:(单位是分钟)
<session-config>
<session-timeout>30</session-timeout>
</session-config>
注:这里是30分钟,分为单位
(2)在tomcat下的conf\server.xml中设置:(单位是秒)
<Context path="/livsorder" docBase="/home/httpd/html/livsorder"
defaultSessionTimeOut="3600" isWARExpanded="true" isWARValidated="false" isInvokerEnabled="true"
isWorkDirPersistent="false"/>
注:单位为秒
(3)在项目的web.xml中设置:(单位是分钟)
<session-config>
<session-timeout>15</session-timeout>
</session-config>
注:15指分钟,单位是分钟
(4)在java代码中设置:(单位是秒)
HttpSession ses = request.getSession();
ses.setMaxInactiveInterval(900);
注:参数900单位是秒,即在没有活动15分钟后,session将失效。单位为秒,设置为-1表示永不过期。
上一篇:json格式转换
下一篇:jq处理文件上传问题reader问题