Session基本使用及原理和使用细节

目录

一、Session基本使用

二、Session原理

三、Session使用细节


一、Session基本使用

服务端会话跟踪技术:将数据保存到服务端

JavaEE提供HttpSession接口,来实现一次会话的多次请求间数据共享功能

 使用:

1、获取Session对象

HttpSession session = request.getSession();

2、Session对象功能:

void setAttribute(String name,Object o):存储数据到session域中

Object getAttribute(String name):根据key,获取值

void removeAttribute(String name):根据key,删除该键值对

代码示例:

ServletDemo1:

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;

@WebServlet("/demo1")
public class ServletDemo1 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //存储到Session中
        //1.获取Session对象
        HttpSession session = request.getSession();
        //2.存储数据
        session.setAttribute("username","zs");
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doGet(request, response);
    }
}

ServletDemo2:

import javax.servlet.*;
import javax.servlet.http.*;
import javax.servlet.annotation.*;
import java.io.IOException;

@WebServlet("/demo2")
public class ServletDemo2 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //获取数据,从session中

        //1.获取Session对象
        HttpSession session = request.getSession();
        //2.获取数据
        Object username = session.getAttribute("username");
        System.out.println(username);

    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doGet(request, response);
    }
}

访问demo1及demo2时控制台输出:

 二、Session原理

Session是基于Cookie实现的

 关闭浏览器后重新访问demo1的浏览器开发者工具显示:

 重新访问demo2的浏览器开发者工具显示:

 三、Session使用细节

 Session钝化、活化:

钝化:在服务器正常关闭后,Tomcat会自动将Session数据写入硬盘的文件中

活化:再次启动服务器后,从文件中加载数据到Session中

Session销毁:

默认情况下,无操作,30分钟自动销毁

<session=config>
    <session-timeout>30</session-timeout>
</session-config>

调用Session对象的invalidate()方法

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
HTTP(Hypertext Transfer Protocol)是一种用于传输超文本的应用层协议。它是建立在TCP/IP协议之上的,基于客户端-服务器模型。HTTP请求的基本原理可以简述如下: 1. 客户端发起请求:客户端(如浏览器)向服务器发起HTTP请求。请求包括请求方法(如GET、POST)、请求URL、请求头部(如Accept、Content-Type)和请求体(可选)等信息。 2. 服务器响应请求:服务器接收到客户端的HTTP请求后,根据请求的内容进行处理,并生成对应的HTTP响应。响应包括响应状态码(如200 OK、404 Not Found)、响应头部(如Content-Type、Content-Length)和响应体等信息。 3. 数据传输:客户端和服务器通过TCP/IP协议进行数据传输。客户端在发送请求时会打开一个TCP连接,发送请求数据;服务器收到请求后会返回响应数据。请求和响应数据都是通过TCP连接传输的。 4. 连接管理:默认情况下,HTTP是一种无状态协议,即每个请求和响应之间没有关联。为了维护状态,可以使用Cookie或者Session等机制来跟踪客户端和服务器之间的状态。 需要注意的是,HTTP是一种明文协议,数据在传输过程中是以明文形式进行传输的,因此不安全。为了保证传输安全,可以使用HTTPS(HTTP Secure)协议,它在HTTP的基础上添加了SSL/TLS加密层,对数据进行加密和认证。 以上是HTTP请求的基本原理,实际上,HTTP协议还有很多细节和特性,如缓存机制、认证机制、重定向等,开发者在实际应用中需要根据需求和具体情况进行处理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏志121

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值