Session用法

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表示永不过期。






  • 25
    点赞
  • 87
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
在计算机科学中,会话(session)是指一次交互式对话过程,其中包含了一系列的请求和响应。在Web开发中,会话通常是指Web浏览器与Web服务器之间的交互过程。 在编程中,会话是一种保存用户数据的机制,它允许我们在不同页面之间共享相同的数据。通常,会话数据存储在服务器上,并通过会话ID与每个客户端相关联。这个会话ID可以通过Cookie或URL参数传递。 在Python中,我们可以使用内置的`session`模块来实现会话管理。下面是一个使用`session`模块的例子: ```python from flask import Flask, session, redirect, url_for, escape, request app = Flask(__name__) app.secret_key = 'secret_key' # 设置一个密钥 @app.route('/') def index(): if 'username' in session: username = session['username'] return 'Logged in as ' + username + '<br>' + \ "<b><a href = '/logout'>click here to log out</a></b>" return "You are not logged in <br><a href = '/login'></b>" + \ "click here to log in</b></a>" @app.route('/login', methods = ['GET', 'POST']) def login(): if request.method == 'POST': session['username'] = request.form['username'] return redirect(url_for('index')) return ''' <form action = "" method = "post"> <p><input type = text name = username></p> <p><input type = submit value = Login></p> </form> ''' @app.route('/logout') def logout(): session.pop('username', None) return redirect(url_for('index')) ``` 这个例子中,我们首先导入了`session`模块,并设置了一个密钥,然后在`index()`函数中检查是否已经登录。如果已经登录,则显示欢迎信息和一个注销链接;如果没有登录,则显示登录链接。在`login()`函数中,我们通过`request.form`获取提交的用户名,并将其保存到会话中。在`logout()`函数中,我们使用`session.pop()`方法将用户数据从会话中删除。 需要注意的是,在使用`session`模块之前,必须设置一个密钥,这个密钥用于对会话数据进行加密。在上面的例子中,我们设置了一个简单的密钥,实际应用中需要使用更加复杂和安全的密钥。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值