javaweb之Cookie和Session(总体第八篇)

之前已经学习完了Javaweb之前端三剑客,JQuery,servlet,xml,等一系列内容,接下来学习Cookie和Session了,本文学习视频资源

一、Cookie(饼干)

1、什么是Cookie

  • cookie是服务器通知客户端保存键值对的一种技术
  • 客户端有了cookie后,每次请求都发送给服务器。
  • 每个cookie的大小不能超过4kb

2、如何创建cookie

(1) 首先创建项目

在这里插入图片描述

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="pragma" content="no-cache" />
<meta http-equiv="cache-control" content="no-cache" />
<meta http-equiv="Expires" content="0" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Session</title>
	<base href="http://localhost:8080/13_cookie_session/">
<style type="text/css">

	ul li {
		list-style: none;
	}
	
</style>
</head>
<body>
	<iframe name="target" width="500" height="500" style="float: left;"></iframe>
	<div style="float: left;">
		<ul>
			<li><a href="sessionServlet?action=createOrGetSession" target="target">Session的创建和获取(id号、是否为新创建)</a></li>
			<li><a href="sessionServlet?action=setAttribute" target="target">Session域数据的存储</a></li>
			<li><a href="sessionServlet?action=getAttribute" target="target">Session域数据的获取</a></li>
			<li>Session的存活</li>
			<li>
				<ul>
					<li><a href="sessionServlet?action=defaultLife" target="target">Session的默认超时及配置</a></li>
					<li><a href="sessionServlet?action=life3" target="target">Session3秒超时销毁</a></li>
					<li><a href="sessionServlet?action=deleteNow" target="target">Session马上销毁</a></li>
				</ul>
			</li>
			<li><a href="" target="target">浏览器和Session绑定的原理</a></li>
		</ul>
	</div>
</body>
</html>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="pragma" content="no-cache" />
<meta http-equiv="cache-control" content="no-cache" />
<meta http-equiv="Expires" content="0" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Cookie</title>
	<base href="http://localhost:8080/13_cookie_session/">
<style type="text/css">

	ul li {
		list-style: none;
	}
	
</style>
</head>
<body>
	<iframe name="target" width="500" height="500" style="float: left;"></iframe>
	<div style="float: left;">
		<ul>
			<li><a href="cookieServlet?action=createCookie" target="target">Cookie的创建</a></li>
			<li><a href="cookieServlet?action=getCookie" target="target">Cookie的获取</a></li>
			<li><a href="cookieServlet?action=updateCookie" target="target">Cookie值的修改</a></li>
			<li>Cookie的存活周期</li>
			<li>
				<ul>
					<li><a href="cookieServlet?action=defaultLife" target="target">Cookie的默认存活时间(会话)</a></li>
					<li><a href="cookieServlet?action=deleteNow" target="target">Cookie立即删除</a></li>
					<li><a href="cookieServlet?action=life3600" target="target">Cookie存活3600秒(1小时)</a></li>
				</ul>
			</li>
			<li><a href="cookieServlet?action=testPath" target="target">Cookie的路径设置</a></li>
			<li><a href="" target="target">Cookie的用户免登录练习</a></li>
		</ul>
	</div>
</body>
</html>

在这里插入图片描述

(2)创建cookie

  • 导入这个baseServlet

public abstract class BaseServlet extends HttpServlet {

    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        doPost(req, resp);
    }

    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        // 解决post请求中文乱码问题
        // 一定要在获取请求参数之前调用才有效
        req.setCharacterEncoding("UTF-8");

        String action = req.getParameter("action");
        try {
            // 获取action业务鉴别字符串,获取相应的业务 方法反射对象
            Method method = this.getClass().getDeclaredMethod(action, HttpServletRequest.class, HttpServletResponse.class);
//            System.out.println(method);
            // 调用目标业务 方法
            method.invoke(this, req, resp);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}
  • 创建CookieServlet
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 创建cookie
    在这里插入图片描述
    可以再次运行即可发现报错
    在这里插入图片描述
    在这里插入图片描述

  • 然后就可以查看了
    在这里插入图片描述

  • 这里乱码了
    在这里插入图片描述
    在这里插入图片描述

  • cookie创建流程
    在这里插入图片描述
    这样可以保存在Redis里面,然后客户端每次请求都会携带上这个cookie,然后发起请求的时候就不用每次都登录再访问了。

(3)后端如何获取cookie

在这里插入图片描述

  • Cookie工具类
    在这里插入图片描述
    在这里插入图片描述
  • 为什么能获取cookie呢?
    在这里插入图片描述
  • 获取某一个特定的cookie,是没有提供获取某一个cookie的,而是要进行遍历的时候进行判断。
```java
public class CookieUtils {
/**
* 查找指定名称的 Cookie 对象
* @param name
* @param cookies
* @return
*/
    public static Cookie findCookie(String name , Cookie[] cookies){

        if (name == null || cookies == null || cookies.length == 0) {
            return null;
        }
        for (Cookie cookie : cookies) {
            if (name.equals(cookie.getName())) {
            return cookie;
        }
        }
        return null;
    }
}

(4)如何修改cookie

  • 先创建一个要修改的同名(指的key)的cookie对象
  • 在构造器,同时富裕新的cookie值
  • 调用response.addCookie(newCookie)

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

  • 另外一种方式
    在这里插入图片描述

3、浏览器查看cookie

这个很简单,就不用说了

4、Cookie生命控制

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

5、Cookie有效路径Path的设置

在这里插入图片描述

  • path路径能干嘛
    • Cookie的path属性可以有效的过滤哪些cookie可以发送给服务器,哪些不发
    • path属性是通过请求的地址来进行有效的过滤

在这里插入图片描述

在这里插入图片描述

6、Cookie实现面用户名登录

在这里插入图片描述

  • 编写jsp页面
    在这里插入图片描述

  • 编写Servlet
    在这里插入图片描述

二、Session

1、什么是Session会话

  • Session就一个接口(HTTPSession)
  • Session就是会话,它是用来维护一个客户端和服务器之间关联的一种技术
  • 每个客户端都有自己的Session会话
  • Session会话中,我们经常用来保存用户登录之后的信息

2、如何创建Session和或者(ID号,是否更新)

在这里插入图片描述

  • 如何创建
    request.getSession()第一次调用就是创建,第二次调用就是获取
  • isNew();可以判断是否到底刚创建出来的(true就是刚创建的)

在这里插入图片描述

3、获取Session域数据的存取

在这里插入图片描述

4、Session生命周期

  • 可以设置超时时间:public void setMaxInactiveInterval(int interval) 设置 Session 的超时时间(以秒为单位),超过指定的时长,Session就会被销毁。

    • 值为正数的时候,设定 Session 的超时时长。
    • 负数表示永不超时(极少使用)
  • public int getMaxInactiveInterval()获取 Session 的超时时间

  • public void invalidate() 让当前 Session

  • Session默认的超时时间为30min,因为在Tomcat服务器的配置文件web.xml中默认有配置
    在这里插入图片描述

小结:如果你想个别的修改session的修改超时时间,就可以使用方法进行修改,如果全部修改的话就修改配置文件

在这里插入图片描述

5、浏览器和Session之间关联的技术内幕

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值