前后端存取cookie

一、前端存取cookie

1.前端jsp存入cookie

<%@ page import="java.util.Map" %>
<%@ page contentType="text/html;charset=UTF-8" language="java"  %>
<html>
<head>
    <title>jsp获取cookie</title>
</head>
<body>
<%
    //创建一个cookie包括(key,value)
    Cookie cookie = new Cookie("jspSetCookie","这是我通过jsp存入的cookie");
    //设置cookie的生命周期,如果为负值的话,关闭浏览器就失效
    cookie.setMaxAge(60*60*24*365);
    // 设置Cookie路径,不设置的话为当前路径(对于Servlet来说为request.getContextPath() + web.xml里配置的该Servlet的url-pattern路径部分)
    //cookie.setPath("/");

    response.addCookie(cookie);
%>
</body>
</html>

2.前端jsp获取cookie

<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page import="java.util.Map" %>
<%@ page import="java.util.HashMap" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>前端jsp获取cookie</title>
</head>
<body>
<%
    //将cookie封装到map里
    Map<String, Cookie> cookieMap = new HashMap<String, Cookie>();
    Cookie[] cookies = request.getCookies();
    if (null != cookies) {
        for (Cookie cookie : cookies) {
            cookieMap.put(cookie.getName(), cookie);
        }
    }
%>
<%--显示所有cookie--%>
<table border="1">
    <thead>
    <tr>
        <th>key</th>
        <th>value</th>
    </tr>
    </thead>
    <tbody>
    <%
        for (String key : cookieMap.keySet()
                ) { %>
    <tr>
        <td><%=key%>
        </td>
        <td><%=cookieMap.get(key).getValue()%>
        </td>
    </tr>

    <%
        }
    %>
    </tbody>
</table>
<%--根据key获取cookie--%>
<h2>获取key为jspSetCookie的值:</h2>
<%= cookieMap.get("jspSetCookie").getValue()%>
</body>
</html>

3.前端js存入cookie

引入jquery-cookie.js和jquery.js文件

https://cdn.bootcss.com/jquery/3.2.1/core.js

https://cdn.bootcss.com/jquery-cookie/1.4.1/jquery.cookie.js

//js存入cookie expires:有效期 path:按个路径有效
//是否自动进行编码和解码,true为关闭
$.cookie.raw = true;
//将数据转为json
$.cookie.json= true;
$.cookie("jsSetCookie","这是我通过js存入的cookie",{expires:7,path:'/'});
    var jsonData = {
        'name':{
            'data1':11,
            'data2':22
        }
    };
    $.cookie("jsonData",jsonData);

4.前端读取cookie

$.cookie('jsSetCookie')

jquery-cookie.js使用说明:

  • 创建一个整站cookie
$.cookie('name', 'value');1
  • 创建一个整站cookie ,cookie 的有效期为 7 天
$.cookie('name', 'value', { expires: 7 });1
  • 创建一个仅对 path 路径页面有效的 cookie ,cookie 的有效期为 7 天
$.cookie('name', 'value', { expires: 7, path: '/' });1
  • 读取 cookie
$.cookie('name'); // 如果cookie存在 则获取到cookie值 => 'value'
$.cookie('nothing'); // 如果cookie不存在 则返回 => undefined12
  • 获取所有可见的 cookie
$.cookie(); // 数据格式 => { name: 'value' }1
  • 删除 cookie
$.removeCookie('name'); // => true
$.removeCookie('nothing'); // => false12
  • 删除带属性的cookie
$.cookie('name', 'value', { path: '/' });
// 错误
$.removeCookie('name'); // => false
// 正确
$.removeCookie('name', { path: '/' }); // => true
属性
domain

创建cookie所在网页所拥有的域名

$.cookie('name', 'value', { domain: 'weber.pub' });1
secure

默认是false,如果为true,cookie的传输协议需为https;

$.cookie('name', 'value', { secure: true });
$.cookie('name'); // => 'value'
$.removeCookie('name', { secure: true }); 123
raw

默认为false,读取和写入时候自动进行编码和解码(使用encodeURIComponent编码,使用decodeURIComponent解码),关闭这个功能,请设置为true。

$.cookie.raw = true;1
json
$.cookie.json = true;

注意: row属性

默认jquery-cookie是开启自动编码和解码的。如果要开启的话,后台获取的是经过encodeURIComponent编码的value。

java来解码encodeURIComponent编码的value:
try{
    String value =  URLDecoder.decode(cookieMap.get("jsonData").getValue(),"UTF-8");
    System.out.println("____________value___________="+value);
    map.put("testCookie", testCooke);
}catch (UnsupportedEncodingException e){
    e.printStackTrace();
}
java来encodeURI编码
try{
    String encodeValue = URLEncoder.encode("这是我利用controller存入的,经过encode编码后的cookie","UTF-8");
    response.addCookie(new Cookie("encodeCookie",encodeValue));
}catch (UnsupportedEncodingException e){
    e.printStackTrace();
}

如果$.cookie.raw = true;前端不进行自动编码与解码。数据会原样输出,默认是false,自动进行编解码。

如果$.cookie.json属性设置为true,编解码的cookie将查询不到,注意这个问题,具体原因不知道。

二、后端存取cookie(controller)

1.后端存入cookie 及编码

//controller 存入cookie
@RequestMapping(value = "/setCookie")
@ResponseBody
public Map<String, String> setCookie(
        HttpServletResponse response
) {
    // 存入
    Cookie cookie = new Cookie("controllerSetCookie","这是我通过后台添加的cookie");
    //设置cookie的生命周期,如果为负值的话,关闭浏览器就失效
    cookie.setMaxAge(60*60*24*365);
    // 设置Cookie路径,不设置的话为当前路径(对于Servlet来说为request.getContextPath() + web.xml里配置的该Servlet的url-pattern路径部分)
    //cookie.setPath("/");
    response.addCookie(cookie);
    try{
        String encodeValue = URLEncoder.encode("这是我利用controller存入的,经过encode编码后的cookie","UTF-8");
        response.addCookie(new Cookie("encodeCookie",encodeValue));
    }catch (UnsupportedEncodingException e){
        e.printStackTrace();
    }

    Map<String, String> map = new HashMap<String, String>();
    map.put("info", "存入成功");
    return map;
}

2.后端读取cookie 及解码

(1)通过注解的方式直接获取value

@CookieValue(value = “testCookie”, required = false) String testCooke(适用于少量cookie的情况下)

(2)通过request.getCookies()获取所有cookie,然后遍历分装到map里,然后读取(适用于多个cookie的情况)

// controller 读取cookie
@RequestMapping(value = "/getCookie")
@ResponseBody
public Map<String, Cookie> getCookie(
        @CookieValue(value = "testCookie", required = false) String testCooke,
        HttpServletRequest request
) {
    //将cookie封装到map里
    Map<String,Cookie> cookieMap = new HashMap<String, Cookie>();
    Cookie[] cookies =request.getCookies();
    if (null != cookies){
        for(Cookie cookie:cookies){
            cookieMap.put(cookie.getName(),cookie);
        }
    }
    Map<String, String> map = new HashMap<String, String>();
    try{
        String value =  URLDecoder.decode(cookieMap.get("jsonData").getValue(),"UTF-8");
        System.out.println("____________value___________="+value);
        map.put("testCookie", testCooke);
    }catch (UnsupportedEncodingException e){
        e.printStackTrace();
    }

    return cookieMap;
}

其他操作