记录一下js对session操作,防止老年人记忆里衰退。
Session
JS
//1、在session中添加一条数据
sessionStorage.setItem(sessionKey,sessionValue);
//2、删除的session,还是通过String类型的sessionKey操作它;
sessionStorage.removeItem(sessionKey);
//3、获取存入的session值,通过String类型的sessionKey进行获取;
sessionStorage.getItem(sessionKey);
JAVA
HttpServletRequest request = new HttpServletRequest();//可以直接在方法形参中声明 HttpServletRequest request
//1、在session中添加一条数据,sessionKey为String类型
request.getSession().setAttribute(sessionKey,sessionValue);
//2、获取存入的session值,通过String类型的sessionKey进行获取;
request.getSession().getAttribute();
//3、删除的session,还是通过String类型的sessionKey操作它;
request.getSession().removeAttribute();
**
Cookie
**
JS
/**
* 添加一个cookies,一个小时过期
* @param key 为string类型
* @param value
*/
function setCookie(key, value) {
var expires= new Date();
expires.setTime(expires.getTime() + 60 * 30 * 1000);
document.cookie = key+ "=" + escape(value) + ";expires="
+ expires.toGMTString() + ";path=/";
}
/**
* 读取cookies
* @param key 为String类型
* @returns 读取的key对应的value
*/
function getCookie(key) {
var arr, reg = new RegExp("(^| )" + key+ "=([^;]*)(;|$)");
if (arr = document.cookie.match(reg))
return unescape(arr[2]);
else
return null;
}
/**
* 删除cookies
* @param key 为String类型
*/
function removeCookie(key) {
var expires= new Date();
expires.setTime(expires.getTime() - 60 * 60 * 1000);
var cval = getCookie(key);
if (cval != null)
document.cookie = key+ "=" + cval + ";expires=" + expires.toGMTString()
+ ";path=/";
}
JAVA
仅测试了添加
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;
public class CookiesUtil {
/**
* 根据名字获取cookie
*
* @param request
* @param name cookie名字
* @return
*/
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
*/
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;
}
/**
* 保存Cookie
* @param response HttpServletResponse
* @param name cookieKey
* @param value CookValue
* @param time 存活时间(单位:秒)
* @return
*/
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;
}
}
两者区别:
Cookie:以文本文件格式存储在浏览器中(即本地),存储的数据量(约4kb)有限且安全性不高;
Session:session存储在服务器中,数据安全且不限制存储大小,但占用服务器的资源。当在关闭浏览器后Session会话就结束,网站无法访问该信息,所以它无法保存永久数据;