java web —— JSP状态管理

本文介绍了HTTP协议的无状态特性及其带来的挑战,并详细探讨了两种主要的用户状态保存机制:Cookie与Session。通过对比分析,帮助读者理解这两种机制的原理、应用场景及安全考虑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

      1、http协议无状态性

      2、保存用户状态的两大机制


一、http协议无状态性

      1、无状态是指,当浏览器发送请求给服务器的时候,服务器响应客户端请求。

      2、但是当同一个浏览器再次发送请求给服务器的时候,服务器并不知道它就是刚才那个浏览器

      3、简单地说,就是服务器不会去记得你,所以就是无状态协议

二、保存用户状态的两大机制

      1、Session

      2、Cookie

               (1)是Web服务器保存在客户端的一系列文本信息

               (2)作用:

                                 1)对特定对象的追踪;

                                 2)保存用户网页浏览记录与习惯;

                                 3)简化登录。

              (3)安全风险:容易泄露用户信息

              (4)Jsp中创建与使用Cookie

                               1)创建Cookie对象
                                      Cookie newCookie = new Cookie(String key , Object value);

                               2)写入Cookie对象
                                      response.addCookie(newCookie);

                               3)读取Cookie对象
                                      Cookie[] cookies = request.getCookies();

                               4)常用方法

void setMaxAge(int expiry)设置cookie的有效期,以秒为单位
void setValue(String value)——在cookie创建后,对cookie进行赋值 
String getName()——获取cookie的名称 
String getValue()——获取cookie的值 
int getMaxAge()——获取cookie的有效时间,以秒为单位 

      3、Session与Cookie的对比

          (1)session

                               1)在服务器端保存用户信息

                               2)session中保存的是Object类型

                               3)随会话的结束而将其存储的数据销毁

                               4)保存重要的信息

          (2)cookie

                             1)在客户端保存用户信息

                             2)cookie保存的是String类型

                             3)cookie可以长期保存在客户端

                             4)保存不重要的用户信息


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值