学Cookie,看这一篇就够了
文章目录
会话的介绍
- 什么是会话
浏览器和服务器之间发生的一系列请求和响应的过程
会话开始:打开浏览器-访问京东
会话结束:关闭浏览器 - 会话产生的数据
Cookie和Session - 本质就是在浏览器或者服务器存取数据的技术
在客户端与服务器端交互的过程中,也会产生一些数据。为了保存会话过程中
分别是产生的数据,在Servlet技术中,提供了两个用于保存会话数据的对象,
##Cookie的概述
- 什么是Cookie
Cookie技术就是在浏览器端存取会话的数据 - Cookie有什么特点?
数据是key-value的形式
数据有存活时间,并且可以修改
不能识别一些特殊符号,所以需要对这个符号进行转码
cookie的创建
- Cookie的创建
Cookie(String name,String value)创建cookie对象
String getName()获取cookie的名称
String getValue()获取cookie的值 - 将cookie发送给浏览器
void addCookie(Cookie cookie)
Cookie作用图解:
存cookie代码如下:
package com.lbl.servlet;
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;
@WebServlet("/cookieServlet")
public class CookieServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//数据是key-vaLue的形式age 18
//创建cookie对象
Cookie cookie1 = new Cookie("username","jack");
Cookie cookie2 = new Cookie("password","1234");
//因为cookie是浏览器保存会话数据的技术,所以必须将cookie发给浏览器
response.addCookie(cookie1);
response.addCookie(cookie2);
}
}
取cookie代码如下:
package com.lbl.servlet;
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;
@WebServlet("/cookieGetServlet")
public class CookieGetServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//获取cookie
Cookie[] cookies = request.getCookies();
//循环所有的cookie
for(Cookie cookie:cookies){
System.out.println(cookie.getName()+": "+cookie.getValue());
}
}
}
运行效果如下:
Cookie设置存活时间
void setMaxAge(int expiry)设置cookie的最大生存时间(单位:秒)
- 默认情况下,浏览器中Cookie的存活时间是一个会话
- 我们有时候需要设置Cookie的存活时间
如果你设置了setMaxAge(60*60),Cookie就会按存活时间保存在硬盘中cookie.setMaxAge(60*60);单位是秒,存活时间就是1个小时。
//数据是key-vaLue的形式age 18
//创建cookie对象
Cookie cookie1 = new Cookie("username","jack");
//设置有效期1小时
cookie1.setMaxAge(60*60);
Cookie的访问路径
- void setPath(String uri)设置cookie的路径——浏览器根据这个路径判断那些cookie要发送给服务器
- 方式1: /myweb 当访问项目下的所有资源,请求都会携带Cookie
- 方式2: /myweb/abc 当访问项目下的abc下所有资源,请求都会携带Cooki
- 方式3: 当访问服务器中所有资源,请求都会携带Cookie
- 默认方式: /myweb 当访问项目下的所有资源,请求都会携带Cookie
Cookie的访问路径图解:
清除Cookie
- 没有清除Cookie的方法
- 可以修改存活时间
- 可以使用空值覆盖原值
- cookie的生存时间单位为:秒
- 要删除已经存在的cookie,后一个用来覆盖cookie必须名称与路径与原来的cookie一致java
Cookie的编码
- Cookie不能识别一些特殊符号,所以需要对这个符号进行转码:
编码:URLEncoder.encode(date,“UTF-8”)
解码:URLDecoder.decode (date,“UTF-8”)
package com.lbl.test;
import org.junit.Test;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.net.URLEncoder;
public class EncodingTest {
//网络编码,post使用的也是这个编码
@Test
public void test() throws UnsupportedEncodingException {
//中文
//明文--密文
String result = URLEncoder.encode("中国", "utf-8");//用utf-8编码明文"中国"
System.out.println(result);
//key namevalue %E4%B8%AD%E5%9B%BD
//密文--明文
String result2 = URLDecoder.decode("%E4%B8%AD%E5%9B%BD", "utf-8");//解码密文
System.out.println(result2);
}
}