Request,Session,Application,Cookie

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:
多个用户共享的应用级别的作用域,在服务器端,相比前两者,这个存在时间是最长的,只有当关闭服务器的时候才死亡!所以他可以活很长时间。

posted @ 2019-06-18 09:17  VizualProphet_zb  阅读(476)  评论(0编辑  收藏  举报