Javaweb - 会话跟踪技术 - Cookie详细介绍与案例分析

272 篇文章 4 订阅
9 篇文章 0 订阅

会话跟踪技术

原理图

请添加图片描述

Cookie

请添加图片描述

Cookie基本使用

创建web项目

  1. 创建webapp骨架项目
  2. 导入pom.xml坐标
  3. 创建java和resources目录

请添加图片描述

发送Cookie案例

编写Servlet
package com.taotao.web;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/**
 * create by 刘鸿涛
 * 2022/4/1 13:29
 */
@WebServlet("/aServlet")
public class AServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //发送Cookie

        //1.创建Cookie对象         键、对值
        Cookie cookie = new Cookie("username","taotao");

        //2.发送Cookie,response
        resp.addCookie(cookie);
    }

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

运行测试-发送Cookie

请添加图片描述

得到Cookie案例

编写Servlet
package com.taotao.web;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/**
 * create by 刘鸿涛
 * 2022/4/1 13:29
 */
@WebServlet("/bServlet")
@SuppressWarnings({"all"})
public class BServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //获取Cookie

        //获取Cookie数组
        Cookie[] cookies = req.getCookies();

        //遍历数组
        for (Cookie cookie: cookies) {
            //获取数据
            String name = cookie.getName();
            if("username".equals(name)){
                String value = cookie.getValue();
                System.out.println(name + " :" + value);
            }
            break;
        }
    }

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

运行测试-获取Cookie

先访问aServlet发送cookie

请添加图片描述

访问bServlet得到发送的cookie

请添加图片描述

Cookie原理

请添加图片描述

响应头set-cookie

请添加图片描述

Cookie使用细节

请添加图片描述

cookie存活时间

请添加图片描述

设置cookie存活时间,可以让cookie驻留在电脑硬盘上

编写aServlet
package com.taotao.web;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

/**
 * create by 刘鸿涛
 * 2022/4/1 13:29
 */
@WebServlet("/aServlet")
public class AServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //发送Cookie

        //1.创建Cookie对象         键、对值
        Cookie cookie = new Cookie("username","taotao");

        //设置cookie的存活时间 1周7天
        cookie.setMaxAge(60*60*24*7);   //单位为秒s

        //2.发送Cookie,response
        resp.addCookie(cookie);
    }

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

运行测试

先访问aServlet,然后关闭浏览器

请添加图片描述

再次打开浏览器,访问bServlet,发现可以得到cookie

请添加图片描述

查看电脑硬盘存在的cookie

请添加图片描述

请添加图片描述

请添加图片描述

请添加图片描述

请添加图片描述

Cookie存储中文

请添加图片描述

默认存储中文报错

请添加图片描述

进行转码:URL编码
package com.taotao.web;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
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.net.URLEncoder;

/**
 * create by 刘鸿涛
 * 2022/4/1 13:29
 */
@WebServlet("/aServlet")
public class AServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //发送Cookie

        //1.创建Cookie对象         键、对值

        String value = "涛涛";
        //URL编码
        value = URLEncoder.encode(value, "UTF-8");
        System.out.println("存储数据:" + value);
        Cookie cookie = new Cookie("username",value);

        //设置cookie的存活时间 1周7天
        cookie.setMaxAge(60*60*24*7);   //单位为秒s

        //2.发送Cookie,response
        resp.addCookie(cookie);
    }

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

测试运行

请添加图片描述

进行解码:UT8-8
package com.taotao.web;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
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.net.URLDecoder;

/**
 * create by 刘鸿涛
 * 2022/4/1 13:29
 */
@WebServlet("/bServlet")
@SuppressWarnings({"all"})
public class BServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //获取Cookie

        //获取Cookie数组
        Cookie[] cookies = req.getCookies();

        //遍历数组
        for (Cookie cookie: cookies) {
            //获取数据
            String name = cookie.getName();
            if(name.equals("username")){
                String value = cookie.getValue();

                //URL解码
                value = URLDecoder.decode(value, "UTF-8");
                
                System.out.println(name + " :" + value);
                break;
            }
        }
    }

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

测试运行

请添加图片描述

Cookie自我理解

cookie的实现是基于HTTP协议的

学了这个cookie,感觉可有意思,还可以设置生命周期

感觉这个cookie中插入点木马病毒,应该也是可以的,

也就是说,只要你们用完浏览器不清除某个站点请求的cookie,那么,那个站点就有可能攻击你

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

鬼鬼骑士

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

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

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

打赏作者

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

抵扣说明:

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

余额充值