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

  • 相关阅读:
    E-R图转换成关系模型
    折叠表格
    ICE在Linux下的安装
    yum 安装gcc
    dll和so文件区别与构成
    linux进入图形界面的方法
    ACE vs Boost: Singleton的实现
    ACE与ASIO之间关于Socket编程的比较
    Linux 下编译安装ACE时遇到的问题及解决
    Linux下安装、配置ACE
  • 原文地址:https://www.cnblogs.com/jiayiblog/p/11043419.html
Copyright © 2020-2023  润新知