Servlet的Cookie和Session机制

Cookies的工作原理

  • 客户端向服务区发起登录请求

  • 服务器脚本(代码)向浏览器发送一组Cookies,例如:姓名,年龄等

  • 浏览器将这些信息存储在本地计算机上,以备将来使用

  • 当下一次浏览器向web服务器发送任何请求时。浏览器会把这些Cookies信息发送到服务器,服务器将使用这些信息来识别账户

[](()Cookies构成

Cookies通常设置在HTTP头信息中,设置Cookie的http请求,会向Servlet发送如下信息

在这里插入图片描述

  • Set-Cookie头包含了一个名称值对,一个GMT日期,一个路径和一个域,名称和值都会被URL编码

  • expires字段是一个命令,告诉浏览器在给定的时间和日期之后过去(“忘记”)该Cookie

  • 如果浏览器被配置为存储Cookies,他将会保留此信息知道到期日期

如果用户端的浏览器指向任何匹配该Cookie的路径和域的页面,他会重新发送Cookie到服务器,浏览器的头信息可能会如下:

在这里插入图片描述

此时Servlet就能够通过请求方法request.getCookies()访问Cookie,该方法将返回一个Cookie对象的数组

[](()Servlet操作Cookie方法

在这里插入图片描述

[](()代码示例:

如果想要了解IDEA配置Tomcat运行Servlet项目,可点击

[IDEA配置Tomcat运行servlet详解](()

具体步骤,创建两个后端类,分别为:

  • 设置cookie信息

  • 获取cookie信息

设置cookie信息代码

import javax.servlet.ServletException;

import javax.servlet.http.Cookie;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletRespons 《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 e;

import java.io.IOException;

import java.io.PrintWriter;

public class SetCookieServlet extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

//1.创建Cookie对象

//首先需要一个cookie对象,这里我们需要两个cookie对象,一个来存储用户名(username——java),一个来存储密码(pwd——javas)

Cookie username = new Cookie(“uesrname”,“java”);

Cookie pwd = new Cookie(“pwd”,“javas”);

//当我们创建好两个cookie对象之后,就可以对这两个对象进行一系列操作

//比如:设置他的过期时间,这里我们将username的过期时间设置为永久

username.setMaxAge(-1);

//密码pwd的过期时间设置为一分钟,注意他的过期时间是以秒为单位

pwd.setMaxAge(60);

//2.将 Cookie 对象关联到response上

resp.addCookie(username);

resp.addCookie(pwd);

//显示给用户部分的信息

resp.setCharacterEncoding(“utf-8”);

resp.setContentType(“text/html”);

//然后写入响应给客户端的内容

PrintWriter writer = resp.getWriter();

writer.println(“

Cookie 设置成功

”);

}

@Override

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

this.doGet(req, resp);

}

}

注意:一定不要忘记配置web.xml文件

结果验证:

在这里插入图片描述

获取cookie信息代码

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;

public class GetCookieServlet extends HttpServlet {

@Override

protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

//读取Cookie的信息

//因为客户端的cookie可能会有多个,所以我们使用数组来接收,注意:cookie是从request获取的

Cookie[] cookies = req.getCookies();

resp.setContentType(“text/html”);

resp.setCharacterEncoding(“utf-8”);

PrintWriter writer = resp.getWriter();

//然后读取cookie的内容

for (Cookie item: cookies

) {

writer.println(String.format(“

Cookie key: %s,Cookie value: %s

”,item.getName(),item.getValue()));

}

}

@Override

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {

this.doGet(req, resp);

}

}

注意

1.不要忘记配置web.xml文件

2.因为上面我们设置cookie信息的时候,pwd的过期时间为一分钟,当我们要去获取cookie信息的时候就看时间不够,所以建议修改更长的过期时间。

验证结果

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值