欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

java web笔记之cookie和session

程序员文章站 2022-03-01 17:17:02
...

什么是会话?

服务器和客户端之间进行数据通信的一种技术,用来识别不同的客户端

客户端和服务器之间发生的一系列连续的请求和响应的过程,打开浏览器进行操作到关闭浏览器的过程,就是一次会话。

会话状态是服务器和浏览器在会话过程中产生的状态信息,借助于会话状态,服务器能够把属于同一会话的一系列请求和响应过程关联起来。

实现会话有两种方式:

  • Session
  • Cookie

Session 常用方法:

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");
}

Cookie

Cookie 是浏览器内置的一个文本文件,用来存储数据,功能和 Session 类似,但是 Session 是服务器提供的,Cookie 是浏览器提供的

浏览器保存了某个 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 就于是否关闭浏览器无关了。

JSP 内置对象作用域

request、session、pageContext、application 都可以用来存储数据

它们有什么区别?

存储数据的作用域不同

pageContext < request < session < application

pageContext:只在当前页面有效

request:在同一次请求中有效

session:在同一次会话中有效

application:在整个 Web 应用中有效

EL 可以作用于 pageContext、request、session、application

优先级

pageContext > request > session > application

<%
    pageContext.setAttribute("name", "pageContext");
    request.setAttribute("name", "request");
    session.setAttribute("name", "session");
    application.setAttribute("name", "application");
%>
${pageScope.name}<br/>
${requestScope.name}<br/>
${sessionScope.name}<br/>
${applicationScope.name}