【javaweb】 -Cookie、Session

Cookie、Session

会话

会话:用户打开一个浏览器,点击了很多超链接,访问多个Web资源,关闭浏览器,这个过程称之为会话。
有状态会话
一个网站,怎么证明自己来过?
客户端 服务端
1. 服务端给客户端一个信件
2. 客户端下次访问服务端带上信件就可以了:Cookie
3. 服务器登记你来过,下次客户端来的时候进行匹配:Session

保存会话的两种技术

Cookie

  • 客户端技术(响应、请求

Session

  • 服务端技术,利用这个技术,可以保存用户的会话信息

1.cookie

1.从请求中拿到cookie信息
2.服务器响应给客户端cookie

package com.java.servlet;

import javafx.scene.chart.PieChart;

import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import java.io.IOException;
import java.io.PrintWriter;
import java.util.Date;


//保存用户上次访问时间
public class CookieDemo01 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //服务器告诉你,你来的时间,把这个时间转化为信件(cookie),你下带来,我就知道了
        req.setCharacterEncoding("utf-16");
        resp.setCharacterEncoding("utf-16");
        PrintWriter out = resp.getWriter();
        //cookie,服务器端从客户端获取
        Cookie[] cookies = req.getCookies();
        //判断cookies是否存在
        if(cookies!=null){
            out.write("上次访问的时间");
            for(int i = 0;i<cookies.length;i++){
                Cookie cookiee = cookies[i];
                if (cookiee.getName().equals("name")){
                    //获取cookie中的时间
                    long time = Long.parseLong(cookiee.getValue());
                    Date data = new Date(time);
                    out.write(data.toLocaleString());
                }

            }

        }else{
            out.write("第一次访问站点");
        }

        Cookie cookie = new Cookie("name", System.currentTimeMillis()+"");
        //设置cookie有效期s
        cookie.setMaxAge(60*60);
        resp.addCookie(cookie);
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        super.doPost(req, resp);
    }
}

cookie位置:一般保存在本地目录下的appdata下
cookie上限:

  • 一个cookie只能保存一个信息
  • 一个web站点可以给浏览器发送多个cookie,最多存放20个
  • cookie大小限制4kb
  • 浏览器上限300个
    cookie删除:
  • 不设置有效期,关闭浏览器,自动失效
  • 设置为0,直接删除
cookie.setMaxAge(0);
JavaWeb中的CookieSession是用于在服务器和客户端之存储和传递数据的机制。 Cookie是在客户端(浏览器)保存少量数据的文本文件,它由服务器发送给浏览器,并在浏览器下一次向同一服务器发送请求时被浏览器携带过去。Cookie可以用于实现用户认证、记住登录状态、记录用户行为等功能。在JavaWeb中,可以使用`javax.servlet.http.Cookie`类来创建和设置CookieSession是在服务器端存储用户信息的一种机制。当用户第一次访问服务器时,服务器会为该用户创建一个唯一的会话标识(Session ID),并将该标识保存在Cookie中发送给客户端。客户端在后续的请求中会带上这个Session ID,服务器通过这个Session ID可以获取到对应的会话信息。在JavaWeb中,可以使用`javax.servlet.http.HttpSession`类来创建、获取和操作SessionCookieSession的区别主要有: 1. 存储位置:Cookie存储在客户端,Session存储在服务器端。 2. 容量限制:Cookie有大小限制,一般为4KB左右;Session可以存储较大量的数据。 3. 安全性:Cookie数据存储在客户端,容易被恶意篡改;Session数据存储在服务器端,相对较安全。 4. 生命周期:Cookie可以设置过期时间,可以长期保存在客户端;Session默认情况下会在一段时间内保持活跃,超过时间会被销毁。 在实际应用中,CookieSession常常结合使用,通过Cookie存储Session ID来实现用户的身份验证和状态管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值