什么是cookies:
cookie实际上是一个存在你硬盘里的数据,但是这些数据很特殊,只能由web应用提交给浏览器帮助存储,并且我们还能读取浏览器存在本地的cookie
web应用一般只在cookie中存储一些用户信息等少量且暂时的数据,数据量大则不适合存储在cookies
cookie的操作:
添加cookie
Cookie cookie = new Cookie(“”,“”);
第一个参数是cookie的名字,第二个参数是cookie的值,如果值是中文,要使用URLEncoder.encode("","")进行编码:
URLEncoder.encode("","")的第一个参数是value,第二个参数是:编码方式
cookie的访问路径:
因为不是所有的cookie都能够被其他的servlet访问,所以要设置访问的路径权限;
cookie.setPath("");默认值是项目路径下;
里面的路径是以项目名+要被访问的 url-pattern的绝对路经;
设置cookie的存在时间
cookie.setMaxAge(secn); 参数是秒;
默认值是-1,即:关闭浏览器时就清除cookie;
当设置为0的时候:创建完cookie,使用后马上就 删除;
因为时间到了,又因为,cookie没有清除方法,所以设置为 0,就相当于清除方法;
当设置时间大于0,当时间到达后就会自动删除
cookie注意事项:
cookie只能保存少量的数据,大约4K;
cookie可以被客户禁用,所以使用应该注意
cookie安全性比较低,敏感信息不要放在其中,而且注意要加密
cookie只能存储字符串
cookie的数量有限制
cookie工具类:
package com.newcapec.util.sys;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.util.HashMap;
import java.util.Map;
/**
* @Title: cookis的相关操作
* @ClassName: com.newcapec.util.sys.CookiesUtil.java
* @Description:
*
* @Copyright 2016-2018 - Powered By 研发中心
* @author: FLY
* @date: 2018-11-02 15:56
* @version V1.0
*/
public class CookiesUtil {
/**
* 根据名字获取cookie
*
* @param request
* @param name cookie名字
* @return Cookie
*/
public static Cookie getCookieByName(HttpServletRequest request, String name) {
Map<String, Cookie> cookieMap = ReadCookieMap(request);
if (cookieMap.containsKey(name)) {
Cookie cookie = (Cookie) cookieMap.get(name);
return cookie;
} else {
return null;
}
}
/**
* 将cookie封装到Map里面
*
* @param request
* @return Map<String, Cookie>
*/
private static Map<String, Cookie> ReadCookieMap(HttpServletRequest request) {
Map<String, Cookie> cookieMap = new HashMap<String, Cookie>();
Cookie[] cookies = request.getCookies();
if (null != cookies) {
for (Cookie cookie : cookies) {
cookieMap.put(cookie.getName(), cookie);
}
}
return cookieMap;
}
/**
* 保存Cookies
*
* @param response response响应
* @param name cookie的名字
* @param value cookie的值
* @param time cookie的存在时间
*/
public static HttpServletResponse setCookie(HttpServletResponse response, String name, String value, int time) {
// new一个Cookie对象,键值对为参数
Cookie cookie = new Cookie(name, value);
// tomcat下多应用共享
cookie.setPath("/");
// 如果cookie的值中含有中文时,需要对cookie进行编码,不然会产生乱码
try {
URLEncoder.encode(value, "utf-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
// 单位:秒
cookie.setMaxAge(time);
// 将Cookie添加到Response中,使之生效
response.addCookie(cookie); // addCookie后,如果已经存在相同名字的cookie,则最新的覆盖旧的cookie
return response;
}
/**
* <p>删除无效cookie</p>
* <p>无效☞1.过时 2.未发布</p>
*
* @param request 请求
* @param response 响应
* @param deleteKey 需要删除cookie的名称
*/
private void delectCookieByName(HttpServletRequest request, HttpServletResponse response, String deleteKey) throws NullPointerException {
Map<String, Cookie> cookieMap = ReadCookieMap(request);
for (String key : cookieMap.keySet()) {
if (key == deleteKey && key.equals(deleteKey)) {
Cookie cookie = cookieMap.get(key);
// 默认值是-1,即:关闭浏览器时就清除cookie;
// 当设置为0的时候:创建完cookie,使用后马上就删除;
// 因为时间到了,又因为,cookie没有清除方法,所以设置为 0,就相当于清除方法;
// 当设置时间大于0,当时间到达后就会自动删除
cookie.setMaxAge(0);//设置cookie有效时间为0
cookie.setPath("/");//不设置存储路径
response.addCookie(cookie);
}
}
}
}
添加一个cookie
执行效果