会话用来识别不同的客户端,客户端和服务器之间发生的一系列连续的请求和响应的过程,打开浏览器进行操作到关闭浏览器的过程,就是一次会话。
会话状态是服务器和浏览器在会话过程中产生的状态信息,借助于会话状态,服务器能够把属于同一会话的一系列请求和响应过程关联起来。
1.Session
2.Cookie
String getId()
void setAttribute(String key,Object value)
void getAttribute(String key)
void removeAttribute(String key)
void invalidate() 设置 session 失效
${sessionScope.username},欢迎回来!<a href="/logout">退出登录</a>
@Override protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { HttpSession session = req.getSession(); session.invalidate(); resp.sendRedirect("download.jsp"); }
pageContext < request < session < application
pageContext:只在当前页面有效
request:在同一次请求中有效
session:在同一次会话中有效
application:在整个 Web 应用中有效
pageContext > request > session > application
Cookie 是浏览器内置的一个文本文件,用来存储数据,功能和 Session 类似,但是 Session 是服务器提供的,Cookie 是浏览器提供的。
浏览器保存了某个 Cookie 之后,每次访问服务器,都会将这个 Cookie 带到服务器,服务器在做响应的时候,又会将 Cookie 再传回到浏览器中,Cookie 会随着请求和响应在服务器和浏览器之间来回传递。
Cookie cookie = new Cookie("name", "tom"); resp.addCookie(cookie);
在这里插入代码片
Cookie[] cookies = request.getCookies(); for (Cookie cookie : cookies) { String name = cookie.getName(); String value = cookie.getValue(); int maxAge = cookie.getMaxAge(); out.write(name+"-"+value+"-"+maxAge+"<br/>"); } //setMaxAge(int time) 给 Cookie 设置有效期,单位为秒,一旦设置有效期之后,Cookie 就与是否关闭浏览器无关了。