JAVAEE网课笔记

Servlet

5.Cookie对象

 5.1.Cookie的创建和发送

        通过 new Cookie("key","value");来创建一个 Cookie 对象,要想将 Cookie 随响应发送到客户端,需要先添加到response 对象中,response.addCookie(cookie);此时该 cookie 对象则随着响应发送至了客户端。在浏览器上可以看见。

//创建Cookie对象
Cookie cookie = new Cookie("uname","zhangsan");
//发送Cookie对象
response.addCookie(cookie);

5.2.Cookie的获取

        在服务器端只提供了一个 getcookies()的方法用来获取客户端回传的所有 cookie 组成的一个数组,如果需要获取单个 cookie 则需要通过遍历,getName()获取 Cookie 的名称,getValue()获取 Cookie 的值。

//获取Cookie数组
Cookie[] cookies = request.getCookies();
//判断数组是否为空
if(cookies != null && cookies.length > 0){
    //遍历Cookie数组
    for(Cookie cookie:cookies){
        System.out.println(cookie.getName());
        System.out.println(cookie.getValue());
    }
}

5.3.Cookie设置到期时间

        除了 Cookie 的名称和内容外,我们还需要关心一个信息,到期时间,到期时间用来指定该 cookie 何时失效。默认为当前浏览器关闭即失效。我们可以手动设定 cookie 的有效时间(通过到期时间计算),通过 setMaxAge(inttime);方法设定 cookie 的最大有效时间,以秒为单位。
到期时间的取值
        ·负整数
  若为负数,表示不存储该 cookie。        
 cookie 的 maxAge 属性的默认值就是-1,表示只在浏览器内存中存活,一旦关闭浏览器窗        口,那么 cookie 就会消失。
        正整数
若大于0的整数,表示存储的秒数。
表示 cookie 对象可存活指定的秒数。当生命大于0时,浏览器会把 Cookie 保存到硬盘上,就算关闭浏览器就算重启客户端电脑,cookie 也会存活相应的时间。
        ·零
若为 0,表示删除该 cookie。cookie 生命等于0是一个特殊的值,它表示 cookie 被作废!也就是说,如果原来浏览器已经保存了这个Cookie,那么可以通过 cookie 的 setMaxAge(0)来删除这个 cookie。无论是在浏览器内存中,还是在客户端硬盘上都会删除这个 Cookie。
设置Cookie对象指定时间后失效

        //获取cookie对象
        Cookie cookie = new Cookie("uname03","lisi");
        //设置失效时间
        cookie.setMaxAge(-1); //负整数,表示浏览器关闭失效,默认
        resp.addCookie(cookie);

        //获取cookie对象
        Cookie cookie02 = new Cookie("uname04","wangwu");
        //设置失效时间
        cookie.setMaxAge(20); //正整数,存活指定秒数
        resp.addCookie(cookie02);

        //获取cookie对象
        Cookie cookie03 = new Cookie("uname05","zhaoliu");
        //设置失效时间
        cookie.setMaxAge(0); //0,表示删除
        resp.addCookie(cookie03);

5.4.Cookie的注意点

·Cookie保存在当前浏览器中。 
在一般的站点中常常有记住用户名这样一个操作,该操作只是将信息保存在本机上,换电脑以后这些信息就无效了。而且 cookie 还不能跨浏览器。



·Cookie存中文问题



·Cookie 中不能出现中文,如果有中文则通过 URLEncoder.encode()来进行编码,获取时通过URLDecoder.decode()来进行解码。

String name = "姓名";
String value = "张三";
//通过 URLEncoder.encode()来进行解码
name = URLEncoder.encode(name);
value = URLEncoder.encode(value);
//创建Cookie对象
Cookie cookie = new Cookie(name,value);
//发送Cookie对象
response.addCookie(cookie);
//获取时通过 URLEncoder.decode()来进行解码
URLDecoder.decode(cookie.getname());
URLDecoder.decode(cookie.getvalue());

·同名Cookie问题

如果服务器端发送重复的Cookie那么会覆盖原来有的Cookie。

5.5.Cookie的路径

        Cookie的setPath设置Cookie的路径,这个路径直接决定服务器的请求是否会从浏览器中加载某些cookie。

情景一:当前服务器下任何项目的任意资源都可获取Cookie对象

/*当前项目路径为: s01 */
Cookie cookie = new Cookie("xxx","XXX");
//设置路径为"/",表示在当前服务器下,任何项目的任意资源,都可获取cookie对象
cookie.setPath("/");
response.addCookie(cookie);

情景二:当前项目下的资源可获取Cookie对象(默认不设置Cookie的path)

/*当前项目路径为: s01 */
Cookie cookie = new Cookie("xxx","XXX");
//设置路径为"/s01",表示在当前服务器下,任何项目的任意资源,都可获取cookie对象
cookie.setPath("/s01"); //默认情况,可不设置path的值
response.addCookie(cookie);

情景三:指定项目下的资源可获取Cookie对象

6.HttpSession对象


        HttpSession对象是 javax.servlet.http.HttpSession 的实例,该接口并不像 HttpServletRequest  或 HtpservletResponse 还存在一个父接口,该接口只是一个纯粹的接口。这因为 session 本身就属于 HTTP 协议的范畴。
        对于服务器而言,每一个连接到它的客户端都是一个 session,servlet 容器使用此接口创建 HTTP 客户端和HTTP 服务器之间的会话。会话将保留指定的时间段,跨多个连接或来自用户的页面请求。一个会话通常对应于个用户,该用户可能多次访问一个站点。可以通过此接口查看和操作有关某个会话的信息,比如会话标识符、创建时间和最后一次访问时间。在整个session 中,最重要的就是属性的操作。

        session 无论客户端还是服务器端都可以感知到,若重新打开一个新的浏览器,则无法取得之前设置的session,因为每一个 session 只保存在当前的浏览器当中,并在相关的页面取得。


        Session 的作用就是为了标识一次会话,或者说确认一个用户;并且在一次会话(一个用户的多次请求)期间共享数据。我们可以通过 request.getsession()方法,来获取当前会话的 session 对象。

6.1标识符 JESSIONID

6.2. session域对象

        Session 用来表示一次会话,在一次会话中数据是可以共享的,这时 session 作为域对象存在,可以通过setAttribute(name,value)方法向域对象中添加数据,通过 getAttribute(name)从域对象中获取数据,通过removeAttribute(name)从域对象中移除数据。

//获取session对象
HttpSession session = request.getSession();
//设置session域对象
session.setAttribute("uname", "admin");
//获取指定名称的session域对象
Strinig uname = (String)request.getAttribute("uname");
//移除指定名称的session域对象
session.removeAttribute("uname");

        数据存储在 session 域对象中,当 session 对象不存在了,或者是两个不同的 session 对象时,数据也就不能共享了。这就不得不谈到 session 的生命周期。

6.3. session对象的销毁

6.3.1. 默认时间到期
*              最大不活动时间,当指定时间内,没有做任何操作。
*              Tomcat服务器设置session的最大不活动时间为30分钟
*              可以手动修改服务器的时间(不建议)
*                  在Tomcat安装包的conf目录中,对应web.sml文件
*                  <session-config>
*                          <session-timeout>30</session-timeout>
*                  </session-config>
6.3.2.手动设置最大不活动时间

                设置最大不活动时间,单位秒

                setMaxInactiveInterval(秒数)

                获取最大不活动时间,返回秒

                getMaxInactiveInterval()

6.3.3. 关闭服务器

        session底层依赖cookie,cookie默认关闭浏览器失效

6.3.4. 关闭服务器

服务器关闭,session对象就销毁了

6.3.5.

        session.invalidate()

        //创建或获取Session
        HttpSession session = req.getSession();

        System.out.println("Session03: " + session.getId());

        //获取最大不活动时间
        System.out.println("最大不活动时间" + session.getMaxInactiveInterval());
        //设置最大不活动时间
        session.setMaxInactiveInterval(10);

        //手动销毁
        session.invalidate();

7.ServletContext对象


        每一个 web 应用都有且仅有一个Servletcontext 对象,又称 Application 对象,从名称中可知,该对象是与应用程序相关的。在 WEB 容器启动的时候,会为每一个 WEB 应用程序创建一个对应的 Servletcontext 对象。


        该对象有两大作用,第一、作为域对象用来共享数据,此时数据在整个应用程序中共享; 第二、该对象中保存了当前应用程序相关信息。例如可以通过 getServerinfo()方法获取当前服务器信息,getRealPath(String path)获取资源的真实路径等。        

7.1. ServletContext对象的获取

*      每一个web应用有且只有一个servletContext对象,又称为application对象
       ① 获取ServletContext 对象的途径有很多。比如:

        1.通过request对象获取

ServletContext servletContext01 = req.getServletContext();

        2.通过session对象获取

ServletContext servletContext02 = request.getSession().getServletContext();

         3.通过servletConfig对象获取

ServletContext servletcontext = getServletConfig().getServletContext();

        4.在Servlet类中直接获取

ServletContext servletContext04 = getServletContext();
②常用方法及其作用
*          获取项目在服务器中的真实路径 getRealPath()
*          获取当前服务器的版本信息 getServerInfo()
③ServletContex作用域
*          在整个应用程序中有效,服务器关闭失效
*          setAttribute()
*          getAttribute()
*          removeAttribute()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值