JavaWeb-05 session + application

1 Cookie基本概念

Cookie(客户端,不是内置对象[所以要new]): Cookie是由 服务端生成的,再发送给客户端保存

  • 相对于 本地缓存的作用:客户端->服务端
  • 就比如你看一个hello.mp4,第一次看的时候由服务端生成,并发送给客户端,第二次再看的时候本地已经有保留
  • 作用:提高访问服务端的效率,但是缺点安全性较差(比如存了用户名、密码)

2 提供常用的方法:

  1. Cookie: name=value
  2. public Cookie(String name,String value) //由javax.servlet.http.Cookie这个类产生Cookie对象
  3. String getName() 获取name
  4. String getValue() 获取value
  5. void setMaxAge(int expiry); //最大有效期(秒)

3 具体实例

  1. 服务端准备Cookie
    response.addCookie(Cookie cookie)
  2. 页面跳转(转发、重定向)
  3. 客户端获取cookie: request.getCookies();

注意:
1.服务端增加cookie:response对象,客户端获取对象:request对象
2.不能直接获取某一个单独对象,只能一次性将全部的cookie拿到

  • 通过F12可以发现 除了自己设置的Cookie对象外,还有一个name为 JSESSIONID的cookie
  • 建议 cookie只保存 英文数字,否则需要进行编码、解码。

4 用途

通常使用Cookie实现 记住用户名功能

【查看Cookie】 - Cookie确实在本机

在这里插入图片描述
在这里插入图片描述

使用Cookie实现 记住用户名 功能

在这里插入图片描述

login.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html"; charset="UTF-8">
    <title>register.jsp--cookie</title>
</head>
<body>
    <%!
      String uname;
    %>
    <%
      boolean flag = false;
      Cookie[] cookies = request.getCookies();
      for (Cookie cookie: cookies) {
        if (cookie.getName().equals("uname")) {
          uname = cookie.getValue();
          flag = true;
        }
      }
      
      if (!flag) {
        out.print("cookie已失效");
      } else {
        out.print("cookie:" + uname);
      }
    %>

    <form action="check.jsp" method="POST">
        用户名:<input type="text" name="uname" id="" value="<%=(uname==null?"":uname)>"><br>
        密码:<input type="password" name="upwd" id=""><br>
        <input type="submit" value="提交">
    </form>
</body>
</html>

check.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html"; charset="UTF-8">
    <title>check.jsp--cookie</title>
</head>
<body>
    <%
        request.setCharacterEncoding("UTF-8");
        String name = request.getParameter("uname");
        String pwd = request.getParameter("upwd");

        //将用户名 加入到Cookie中
        Cookie cookie = new Cookie("name", name);
        
        cookie.setMaxAge(10); //10秒
        response.addCookie(cookie);
        
        response.sendRedirect("A.jsp");
    %>

    
</body>
</html>

1 概念:session(服务端,是内置对象)

session 又称: 会话

[例]
  • 浏览网站 开始-关闭
  • 购物 浏览、付款、退出
  • 电子邮件 浏览、写邮件、退出

开始-结束

2 session机制:

在这里插入图片描述

  1. 客户端第一次请求服务端时,服务端会产生一个session对象(用于保存该客户的信息)
    并且每个session对象 都会有一个唯一的sessionID(用于区分其他session)
  2. 服务端 会产生一个cookie,并且 该cookie的name=JSESSIONID,value=服务端sessionID的值:
  3. 然后 服务端会在 响应客户端的同时 将该cookie发送给客户端,客户端就有了一个cookie(JSESSION)
  4. 因此,客户端的cookie就可以和服务端的sessionID一一对应(JSESSIONID-sessionID)
  5. 客户端第二/n次请求服务端时:服务端会先用客户端cookie中的JSESSIONID 去服务端的session中匹配sessionid,如果匹配成功,说明此用户不是第一次登录,无需登录
  6. session在登录时,分配sessionId

[总结] session:

  1. session存储在服务端
  2. session是在同一个用户(客户)请求时 共享
  3. 实现机制:第一次客户请求时 产生一个sessionid 并复制给 cookie的jsessionid 然后发给客户端。最终通过session的sessionid-cookie的jsessionid

3 session方法:

getId(): 获取sessionId //不一定全为数字,是字符串

boolean isNew(): 判断是否是新用户(第一次访问)

void invalidate(): 使session失效(退出登入、注销)

void setAttribute()

Object getAttribute()

void setMaxInactiveInterval(秒):设置最大有效非活动时间

int getMaxInactiveInterval(): 获取最大有效 非活动时间

示例

在这里插入图片描述

login.jsp
check.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html"; charset="UTF-8">
    <title>check.jsp--cookie</title>
</head>
<body>
    <%
        request.setCharacterEncoding("UTF-8");
        String name = request.getParameter("uname");
        String pwd = request.getParameter("upwd");

        if (name.equals("zs") && pwd.equals("abc")) {
            //登录成功
            session.setAttribute("uname", name);
            session.setAttribute("upwd", pwd);
            //session.setMaxInactiveInterval(10); //10秒

            request.getRequestDispatcher("welcome.jsp").forward(request, response);
        } else {
            //登录失败,跳回登录页面
            request.sendRedirct("login.jsp");
        }
    %>
</body>
</html>
welcome.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html"; charset="UTF-8">
    <title>register.jsp--response</title>
</head>
<body>
    欢迎你:
    <%
        String name = (String)session.getAttribute("uname"); //返回的类型是Object
        //用户没有登录,而是直接通过地址栏 访问welcome.jsp,则必然获取到的name是null
        if (name != null) {
        	out.print(name); 
    	} else { //如果没有登录,应该跳转登录页面
    		request.sendRedirct("login.jsp");
    	}
    %>
</body>
</html>

注销

welcome.jsp
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html"; charset="UTF-8">
    <title>register.jsp--response</title>
</head>
<body>
    欢迎你:
    <%
        String name = (String)session.getAttribute("uname"); 
        //用户没有登录,而是直接通过地址栏 访问welcome.jsp,则必然获取到的name是null
        if (name != null) {
        	out.print(name); 
    %>

    <a href="invlidate.jsp">注销</a>

    <%
    	} else { //如果没有登录,应该跳转登录页面
    		request.sendRedirct("login.jsp");
    	}
    %>
</body>
</html>

客户端在第一次请求服务端时,如果服务端发现 此请求没有JSESSIONID,则会创建一个 name=JSESSIONID的cookie,并返回给客户端

[注]Cookie

  1. 不是内置对象,要使用必须new
  2. 但是,服务端会自动生成一个(服务端自动new一个cookie) name=JSESSIONID的cookie,并返回给客户端

request:只在同一次请求有效
地址栏回车(发出第二次请求)
如果点击F5刷新,则浏览器会自动重复刚才的行为

cookie和session的区别:

-----sessioncookie
保存的位置服务端客户端
安全性服务端客户端
保存的内容ObjectString

[注]

  • 类 - ctrl
  • 对象 - ctrl+t

application 全局对象


  1. String getContextPath() 虚拟路径
  2. String getRealPath(String name) 绝对路径(虚拟路径 相对的绝对路径)

四种范围对象(从小到大)


  • pageContext JSP页面容器 当前页面有效
  • request 请求对象 同一次请求有效
  • session 会话对象 同一次会话有效
  • application 全局对象 全局有效(整个项目有效)

以上4个对象共有的方法

  • Object getAttribute(String name): 根据属性名,获取属性值。
  • void setAttribute(String name,Object obj): 设置属性值(新增或修改)
  • setAttribute(“a”,“b”); //如果a对象之前不存在,则新建一个a对象;如果a之前已经存在,则将a的值改为b。
  • void removeAttribute(String name); 根据属性名,删除对象。

  • pageContext:当前页面有效(页面跳转后无效)
  • request:同一次请求有效,其他请求无效(请求转发后有效,重定向后无效)
  • session:同一次会话有效(无论怎么跳转都有效,关闭/切换浏览器后无效,从登录到退出之前全部都有效)
  • application:全局变量,整个项目运行期间都有效(切换浏览器仍然有效);关闭服务、其他项目 无效
  • ==> 多个项目共享、重启后仍然有效:JNDI
  1. 以上的4个范围对象,通过setAttribute()赋值,通过getAttribute()取值
  2. 以上范围对象,尽量使用最小的范围,因为对象范围越大,造成的性能损耗越大。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实验:内置对象使用 一、实验目的 1、掌握各个内置对象的含义; 2、理解并熟练应用sessionapplication对象。 二、实验内容 1、设计聊天室,在聊天室中,需要通过JSP内置对象application来实时保存特定数量的当前聊天信息。 聊天室的设计包括:用户进行登录,选择聊天室,进行聊天,退出聊天室。 在聊天室中,用户只需输入一个用户名就可以进入聊天室,但是如果当前有人在使用该用户名,那么就必须换一个唯一的用户名。 具体要求:  用户登录成功后,程序会要求用户选择聊天室。可以不设置用户自行建立聊天室的功能,而且在聊天中途不能从一个聊天室切换到另一个聊天室。  进入聊天室后,用户可以从用户信息窗口看到该聊天室中所有用户的用户名,也可以在聊天窗口中看到随时更新的聊天信息。用户可以给所有人或某一个聊天用户发送公共的聊天信息,这个聊天内容大家都可以看到。用户也可以给某个用户发送私人的聊天信息,这种信息属于私聊信息,只有发送者和接收者可以看到。此外,聊天窗口还会出现一些系统公告,比如某某上站、某某离开等消息,另外用户还可以自己定义聊天信息和聊天用户信息刷新的时间间隔。  在用户单击“退出”按钮后,页面关闭,同时applicationsession中保存的信息都将丢失。 三、实验方法 1、用户登录信息使用request对象getParameter()方法得到用户登陆的一些信息; 2、公聊信息可以使用application对象,私聊信息使用session对象。 3、聊天的信息要不断刷新页面,使用户实时看到聊天信息。 4、用户退出时,有两种情况需要考虑:一是用户点击“退出”按钮,二是关闭浏览器,强制退出窗口,可查阅windows感知浏览器关闭的事件的相应方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值