1. Application(ServletContext)
作用范围:所有的用户都可以取得此信息,此信息在整个服务器上被保留。
ServletContext servletContext = this.getServletContext();//在Servlet中获取Application对象方法
servletContext .setAttribute("name", "kaixuan"); //设置一个值进去
servletContext .getAttribute("name"); //获取键值对
服务器只会创建一个ServletContext 对象,所以this.get 到的Application对象都是同一个对象。
2. request
request是表示一个请求,只 要发出一个请求就会创建一个request,它的作用域:仅在当前请求中有效。
用处:常用于服务器间同一请求不同页面之间的参数传递,常应用于表单的控件值传递。
方法:request.setAttribute(); request.getAttribute(); request.removeAttribute(); request.getParameter().
3. session
服务器会为每个会话创建一个session对象,所以session中的数据可供当前会话中所有servlet共享。
会话:用户打开浏览器会话开始,直到关闭浏览器会话才会结束。一次会话期间只会创建一个session对象。
用处:常用于web开发中的登陆验证界面(当用户登录成功后浏览器分配其一个session键值对)。
方法:session.setAttribute(); session.getAttribute(); session.removeAttribute();
获得session对象方法:
在Servlet中:HttpSession session = request.getSession();
由于session属于jsp九大内置对象之一,当然可以直接使用。例如:<%session.serAttribute("name","admin")%>。
session被销毁
1)session超时;
2)客户端关闭后,再也访问不到和该客户端对应的session了,它会在超时之后被销毁;
3)调用session. invalidate();
备注: session是服务器端对象,保存在服务器端。并且服务器可以将创建session后产生的sessionid通过一个cookie返回给客户端,以便下次验证。(session底层依赖于cookie)
4.Cookie
Cookie 是存储在客户端计算机上的文本文件,并保留了各种跟踪信息。
通过 Servlet 设置 Cookie
(1) 创建一个 Cookie 对象
Cookie cookie = new Cookie("key","value");
(2) 设置最大生存周期
cookie.setMaxAge(60*60*24);
(3) 发送 Cookie 到 HTTP 响应头:
response.addCookie(cookie);
通过 Servlet 读取 Cookie
调用 HttpServletRequest 的 getCookies( ) 方法创建一个 javax.servlet.http.Cookie 对象的数组。然后循环遍历数组,并使用 getName() 和 getValue() 方法来访问每个 cookie 和关联的值。
通过 Servlet 删除 Cookie
删除 Cookie 是非常简单的。如果您想删除一个 cookie,那么您只需要按照以下三个步骤进行:
- 读取一个现有的 cookie,并把它存储在 Cookie 对象中。
- 使用 setMaxAge() 方法设置 cookie 的年龄为零,来删除现有的 cookie。
- 把这个 cookie 添加到响应头。
设置cookie、session、application对象有效期
方式一:
<session-config>
<session-timeout>60</session-timeout>
</session-config>
注:单位是分钟 上面则表示session有效期为60分钟,当jsp与服务器60分钟内没有发生交互的话,此时session会失效
方式二:
cookie.setMaxAge("自己指定的时间")。//如果没有指定Cookies对象的有效期,则Cookies对象只存在于客户端的内存。当浏览器关闭时,Cookies就会失效。
session.setMaxInactiveInterval(“自己想要设置的具体时间”)。//默认情况下关闭浏览器session就失效。
以上时间单位为秒
Application:
多个用户共享的应用级别的作用域,在服务器端,相比前两者,这个存在时间是最长的,只有当关闭服务器的时候才死亡!所以他可以活很长时间。