一、session
翻译:会话。
存放位置:服务器端
时长:默认存在时长为半小时。
作用:Session 的主要作用就是通过服务端记录用户的状态,表示用户登录访问某个网站时,实际上是用户与服务器在会话。
常用于验证用户是否已经登录:
HttpSession session = request.getSession(); session.setAttribute("isLogin", true);
用户再次访问时,tomcat在会话对象中查看登录状态:
HttpSession session = request.getSession(); session.getAttribute("isLogin");
二、cookie
翻译:饼干。
存放位置:由服务器端发出,存放于客户端(比如浏览器)
时长:可以根据需要,在浏览器中定时设置清除cookie信息,比如退出浏览器时清除cookie
作用:一般用来保存用户信息,只存放于A浏览器中,在B浏览器中访问,不会出现A浏览器的cookie信息。用户登录或者未登录的情况下都可以存放的用户信息,下次浏览网页可以直接显示数据。浏览器发送http请求时自动附带cookie信息,常用于单点登录。
向客户端发送cookie:
Cookie c =new Cookie("name","value"); //创建Cookie c.setMaxAge(60*60*24); //设置最大时效,此处设置的最大时效为一天 response.addCookie(c); //把Cookie放入到HTTP响应中
读取Cookie:
String name ="name"; Cookie[]cookies =request.getCookies(); if(cookies !=null){ for(int i= 0;i<cookies.length;i++){ Cookie cookie =cookies[i]; if(name.equals(cookis.getName())) //something is here. //you can get the value cookie.getValue(); } }
三、cache
翻译:电脑高速缓冲存储器。
存放位置:客户端
时长:保存的时间同cookie
作用:同样的,只存放于A浏览器中,在B浏览器中访问,不会出现A浏览器的cache信息。用户在访问网页时,保存该网页的页面以及数据。比cookie多存储了页面和css样式。这样,当用户关闭页面或者退出A浏览器之后,再次通过A浏览器访问页面时,打开速度变得比之前快很多(比如视频中的缓存)。