JS和Java对Session和Cookie的操作以及二者之间的基本区别

2 篇文章 0 订阅

记录一下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会话就结束,网站无法访问该信息,所以它无法保存永久数据;

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值