Cookie知识点总结

Cookie知识点总结

  • 概念:
    Cookie 技术其实是浏览器端的数据存储技术,解决了不同请求 需要使用相同的请求数据的问题。我们把请求需要共享的请求数 据,存储在浏览器端,避免用户进行重复的书写请求数据。但是 哪些数据需要使用 Cookie 技术存储起来是一个主观问题,需要在 后台进行响应的时候来告诉浏览器,有些数据其他请求还会使用, 需要存储起来。

  • 解决的问题:
    HTTP 协议是没有记忆功能的,一次请求结束后,相关数据会 被销毁。如果第二次的请求需要使用相同的请求数据怎么办呢? 难道是让用户再次请求书写吗?

  • 特点:
    浏览器端的数据存储技术
    适合少量数据
    键值对
    不安全

  • 使用:
    Cookie 数据存储:

    • 临时存储: 不设置 cookie 信息的存储时间,周期为一次会话, 存储在浏览器内存中
    • 定时存储: 设置存储时间,周期为时间设置,存储在用户电脑 中。
      Cookie的创建和存储

    Cookie的创建和存储

    • 创建Cookie对象:Cookie c=new Cookie(String name, String value);
    • 设置cookie(可选)
    • 设置有效期:c.setMaxAge(int seconds)
    • 设置有效路径:c.setPath(String uri)
    • 响应Cookie信息给客户端:resp.addCookie( c );

    Cookie的获取

    • 获取Cookie信息数组:Cookie[] cks=req.getCookies();
    • 遍历数组获取Cookie信息:
if(cks!=null){
	for(Cookie c:cks){
		String name=c.getName();
		String value=c.getValue();
		System.out.println(name+":"+value);						
							}
				}		
  • 注意:
    一个Cookie对象存储一条数据。多条数据,可以多创建几个Cookie对象进行存储。

  • 特点:
    浏览器端的数据存储技术。
    存储的数据声明在服务器端。
    临时存储:存储在浏览器的运行内存中,浏览器关闭即失效。
    定时存储:设置了Cookie的有效期,存储在客户端的硬盘中,在有效期内符合路径要求的请求都会附带该信息。
    默认cookie信息存储好之后,每次请求都会附带,除非设置有效路径

public class CookieServlet extends HttpServlet {
	@Override
	protected void service(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
		//设置请求编码格式
		req.setCharacterEncoding("utf-8");
		//设置响应编码格式
		resp.setContentType("text/html;charset=utf-8");
		//获取请求信息
		
		//处理请求信息
		//响应处理结果
			//使用Cookie进行浏览器端的数据存储
				//创建Cookie对象
				Cookie c=new Cookie("mouse", "thinkpad");
				Cookie c2=new Cookie("key", "bjsxt");
				//设置Cookie
					//设置Cookie的有效期
					c2.setMaxAge(3*24*3600);
					//设置有效路径
					c2.setPath("/cookie/gc");
				//响应Cookie信息
				resp.addCookie(c);
				resp.addCookie(c2);
			//直接响应
				resp.getWriter().write("Cookie学习");
			//请求转发
			//重定向
	}
}
package com.bjsxt.servlet;

import java.io.IOException;

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

public class GetCookieServlet extends HttpServlet {
	@Override
	protected void service(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
		//设置请求编码格式
			req.setCharacterEncoding("utf-8");
		//设置响应编码格式
			resp.setContentType("text/html;charset=utf-8");
		//获取请求信息
			//获取Cookie信息
				Cookie[] cks=req.getCookies();
				if(cks!=null){
					for(Cookie c:cks){
						String name=c.getName();
						String value=c.getValue();
						System.out.println(name+":"+value);
					}
				}
				
			//获取用户信息
		//处理请求信息
		//响应处理结果
			//直接响应
			//请求转发
			//重定向
	}
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值