cookie基础知识以及JS参考: JavaScript中的document.cookie的使用
JAVA
添加cookie
//保存到缓存中
HttpServletResponse response = ContextHolder.getResponse();
Cookie cookie = new Cookie("username","用户名");
cookie.setMaxAge(5*365*24*60*60);//5年
response.addCookie(cookie);
删除cookie
//一、删除已知名称的Cookie(方案:重新建立同名立即删除类型的Cookie)
Cookie newCookie=new Cookie(“username”,null); //假如要删除名称为username的Cookie
newCookie.setMaxAge(0); //立即删除型
newCookie.setPath(“/”); //项目所有目录均有效,这句很关键,否则不敢保证删除
response.addCookie(newCookie); //重新写入,将覆盖之前的
//二、删除所有Cookie
Cookie[] cookies=request.getCookies();
for(Cookie cookie: cookies){
cookie.setMaxAge(0);
cookie.setPath(“/”);
response.addCookie(cookie);
}
修改cookie
public void editCookie(HttpServletRequest request,HttpServletResponse response,String name,String value){
Cookie[] cookies = request.getCookies();
if (null==cookies) {
return;
} else {
for(Cookie cookie : cookies){
if(cookie.getName().equals(name)){
cookie.setValue(value);
cookie.setMaxAge(5*365*24*60*60);//5年
response.addCookie(cookie);
break;
}
}
}
}
查询cookie
HttpServletRequest request = ContextHolder.getRequest();
Cookie[] cookies = request.getCookies();
for(Cookie c:cookies){
String cName = cookie.getName();
if("name".equals(cName)){
String val = c.getValue();
}
}
JS
添加cookie
///设置cookie
setCookie = function(NameOfCookie, value, expiredays){
//@参数:三个变量用来设置新的cookie:
//cookie的名称,存储的Cookie值,
// 以及Cookie过期的时间.
// 这几行是把天数转换为合法的日期
var ExpireDate = new Date ();
ExpireDate.setTime(ExpireDate.getTime() + (expiredays * 24 * 3600 * 1000));
// 下面这行是用来存储cookie的,只需简单的为"document.cookie"赋值即可.
// 注意日期通过toGMTstring()函数被转换成了GMT时间。
document.cookie = NameOfCookie + "=" + escape(value) +
((expiredays == null) ? "" : "; expires=" + ExpireDate.toGMTString());
}
删除cookie
///删除cookie
delCookie = function(NameOfCookie) {
// 该函数检查下cookie是否设置,如果设置了则将过期时间调到过去的时间;
//剩下就交给操作系统适当时间清理cookie啦
if (getCookie(NameOfCookie)) {
document.cookie = NameOfCookie + "=" +
"; expires=Thu, 01-Jan-70 00:00:01 GMT";
}
}
根据cookie名称获得cookie
///获取cookie值
getCookie =function(NameOfCookie){
// 首先我们检查下cookie是否存在.
// 如果不存在则document.cookie的长度为0
if (document.cookie.length > 0){
// 接着我们检查下cookie的名字是否存在于document.cookie
// 因为不止一个cookie值存储,所以即使document.cookie的长度不为0也不能保证我们想要的名字的cookie存在
//所以我们需要这一步看看是否有我们想要的cookie
//如果begin的变量值得到的是-1那么说明不存在
begin = document.cookie.indexOf(NameOfCookie+"=");
if (begin != -1){
// 说明存在我们的cookie.
begin += NameOfCookie.length+1;//cookie值的初始位置
end = document.cookie.indexOf(";", begin);//结束位置
if (end == -1) end = document.cookie.length;//没有;则end为字符串结束位置
return unescape(document.cookie.substring(begin, end));
}
}
return null;
// cookie不存在返回null
}