servlet中Session的用法

## (1)什么是Session?
服务器端为了保存用户的状态而创建的一个特殊的对象(即session对象)。
 
        当浏览器第一次访问服务器时,服务器会创建session对象(该
    对象有一个唯一的id,一般称之为sessionId),接下来服务器会将
    sessionId以cookie的方式发送给浏览器。
        当浏览器再次访问服务器时,会将sessionId发送过来,服务器
    就可以依据sessionId找到对应的sessinon对象。
 
## (2)如何获得session对象?
### 1)HttpSession s = request.getSession(boolean flag);
 
    HttpSession是一个接口。
    a.当flag为true时,先查看请求当中有没有sessionId,如果没有,就会
    创建一个session对象。如果有sessionId,就会依据sessionId去查找
    对应的session对象,如果找到了就返回该对象,找不到则会创建一个
    新的session对象。
    b.当flag为false时,先查看请求当中有没有sessionId,如果没有,返回
    null。如果有sessionId,就会依据sessionId去查找对应的session对象,如果找到了就返回该对象,找不到,返回null。
 
![](session.png)
 
### 2)HttpSession s = request.getSession();
 
    等价于 request.getSession(true);
 
## (3)常用方法
    session.setAttribute(String name,Object obj);
    Object session.getAttribute(String name);
    session.removeAttribute(String name);
 
![](count.png)    
 
## (4)session超时
a.什么是session超时?
 
    服务器会将空闲时间过长的session对象删除掉。
    注:
        为了节省内存空间。
        大部分服务器默认的超时时间长度为30分钟。
 
b.如何修改超时时间长度?
 
    方式一 修改web.xml
        <session-config>
            <session-timeout>30</session-timeout>
        </session-config>
 
    方式二 编程的方式
 
        session.setMaxInactiveInterval(int seconds);
        设置两次请求之间最大的时间间隔
 
## (5)删除session
    
    session.invalidate();  
 
    
    
## (6)session验证
step1. 登录成功之后,在session对象上绑订一些数据,比如
 
    session.setAttribute("user",user);
 
step2.当用户访问需要保护的资源时,进行session验证,比如
 
    Object obj = session.getAttribute("user");
    if(obj == null){
        //没有登录
        response.sendRedirect("login.jsp");
    }
 
![](checklogin.png)
 
 
## (7)比较session与cookie
session相对于cookie,优点:安全、可以存放大量的数据、支持更丰富的
数据类型。缺点是session会占用服务器端的内存空间,如果session对象
过多,会占用过多的内存空间。
 
 
# 练习
写一个servlet,输出用户上一次访问的时间。如果是第一次访问,输出
“你是第一次访问”。

原文地址:https://www.cnblogs.com/package-java/p/10240921.html

时间: 2024-12-10 22:03:24

servlet中Session的用法的相关文章

php中session的用法

PHP 的Session的使用方法以及安全问题和session的注意事项,session使用过期时间设为0的cookie,并且将一个称为session ID的唯一标识符(一长串字符串),在服务器端同步生成一些session文件(可以自己定义session的保存类型),与用户机关联起来.web应用 程序存贮与这些session相关的数据,并且让数据随着用户在页面之间传递. 本文转自: http://blog.chinaunix.net/u/27731/showart_259031.html 访问网

【转载】C# 中Session的用法

C# 中对 Session 的“(string)”.“.ToString()”与“Convert.ToString”用法笔记 在实际操作当中,我们经常会遇到将 Session 的值转为 String 去判断是否为空或者判断是否有权限访问某页,这里的转换过程如果用得不恰当会抛出异常,给访问者带来不好的用户体验.这里我把它写成笔记,以供参考. 一.当 Session["a"] == null 时, Session["a"].ToString() 抛出异常: (strin

C# 中Session的用法

C# 中对 Session 的“(string)”.“.ToString()”与“Convert.ToString”用法笔记 在实际操作当中,我们经常会遇到将 Session 的值转为 String 去判断是否为空或者判断是否有权限访问某页,这里的转换过程如果用得不恰当会抛出异常,给访问者带来不好的用户体验.这里我把它写成笔记,以供参考. 一.当 Session["a"] == null 时, Session["a"].ToString() 抛出异常: (strin

[javaEE] Servlet中Session的使用

Session是一个域 作用范围:当前会话范围 生命周期:当程序第一次调用request.getSession()创建出客户端的session对象,30分钟没有操作认为超时,这个可以在web.xml中进行配置 调用session.nvalidate()方法销毁session 服务器非正常关闭时销毁session 调用HttpServeletRequest对象的getSession()方法,获取HttpSession对象 调用HttpSession对象的setAttribute()方法,存储值,参

CI中SESSION的用法及其注意

Session 类Session类可以使用户在浏览您的网站时,维持他们的状态并跟踪他们的行为. Session类将每个用户的session信息序列化(serialize)后存储到到cookie中(并同时进行加密).您还可以将session数据存储到数据库中来增强安全性,但是这时要求存储在用户cookie中的session ID值能与数据库中存储的用户session ID值相匹配.程序默认只在cookie中存储session.如果您在要在数据库中存储session的话,需要按照下面指示的方法,在您

requests中session的用法

正常情况下,我们想打开禅道的“组织”视图页面,是需要先在禅道的登录页面输入正确的用户名和密码点击登录,再切换到“组织”视图页面. 如果我们的python代码这样写的话,r1和r2的状态码都是200,但r2.text并不是我们想要的.这是因为,r1和r2请求相当于在2个不同的浏览器中,发出的两个请求,彼此是独立的,那么r2请求就相当于是在没有登录的情况下发出的请求. import requests paylod = {'account':'admin', 'password':'e10adc394

Spring MVC中Session的正确用法&lt;转&gt;

Spring MVC是个非常优秀的框架,其优秀之处继承自Spring本身依赖注入(Dependency Injection)的强大的模块化和可配置性,其设计处处透露着易用性.可复用性与易集成性.优良的设计模式遍及各处,使得其框架虽然学习曲线陡峭,但 一旦掌握则欲罢不能.初学者并不需要过多了解框架的实现原理,随便搜一下如何使用“基于注解的controller”就能很快上手,而一些书籍诸如 “spring in action”也给上手提供了非常优良的选择. 网上的帖子多如牛毛,中文的快速上手,英文的

PHP中SESSION与COOKIE的详细用法

1. PHP的COOKIEcookie 是一种在远程浏览器端储存数据并以此来跟踪和识别用户的机制.PHP在http协议的头信息里发送cookie, 因此 setcookie() 函数必须在其它信息被输出到浏览器前调用,这和对 header() 函数的限制类似.1.1 设置cookie:可以用 setcookie() 或 setrawcookie() 函数来设置 cookie.也可以通过向客户端直接发送http头来设置.1.1.1 使用setcookie()函数设置cookie:bool setc

玩转web之servlet(六)---session介绍及简单使用(登录验证中保存信息)

在浏览器与服务器进行交互时,往往需要把涉及到的一些数据保存下来,这时就需要使用cookie或session进行状态管理. 这篇文章先来说说session怎么用,首先在servlet中创建一个session来保存信息,举个例子,在做登陆验证时,如果登陆成功,需要将用户的信息保存到session中,怎么保存呢?下面给出代码: public class Login_Do extends HttpServlet { String order_name = ""; String order_pa