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

一、Cookie(饼干)

1、什么是Cookie

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

2、如何创建cookie

(1) 首先创建项目

java中cookie和session cookie javaweb_Session

<!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>

java中cookie和session cookie javaweb_Cookie_02

(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
  • java中cookie和session cookie javaweb_html_03


  • java中cookie和session cookie javaweb_html_04


  • java中cookie和session cookie javaweb_Javaweb内容_05

  • 创建cookie
  • java中cookie和session cookie javaweb_Javaweb内容_06

  • 可以再次运行即可发现报错
  • java中cookie和session cookie javaweb_java中cookie和session_07


  • java中cookie和session cookie javaweb_html_08

  • 然后就可以查看了
  • java中cookie和session cookie javaweb_Session_09

  • 这里乱码了
  • java中cookie和session cookie javaweb_Cookie_10


  • java中cookie和session cookie javaweb_Session_11

  • cookie创建流程
  • java中cookie和session cookie javaweb_Cookie_12

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

(3)后端如何获取cookie

java中cookie和session cookie javaweb_Session_13

  • 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)

java中cookie和session cookie javaweb_Session_14


java中cookie和session cookie javaweb_Cookie_15

  • 另外一种方式

3、浏览器查看cookie

这个很简单,就不用说了

4、Cookie生命控制

java中cookie和session cookie javaweb_Session_16


java中cookie和session cookie javaweb_Session_17


java中cookie和session cookie javaweb_Session_18


java中cookie和session cookie javaweb_Javaweb内容_19

5、Cookie有效路径Path的设置

java中cookie和session cookie javaweb_Cookie_20

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

java中cookie和session cookie javaweb_Session_21

java中cookie和session cookie javaweb_java中cookie和session_22

6、Cookie实现面用户名登录

java中cookie和session cookie javaweb_Cookie_23

  • 编写jsp页面
  • java中cookie和session cookie javaweb_html_24

  • 编写Servlet
  • java中cookie和session cookie javaweb_html_25

二、Session

1、什么是Session会话

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

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

java中cookie和session cookie javaweb_java中cookie和session_26

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

java中cookie和session cookie javaweb_Cookie_27

3、获取Session域数据的存取

java中cookie和session cookie javaweb_Cookie_28

4、Session生命周期

  • 可以设置超时时间:public void setMaxInactiveInterval(int interval) 设置 Session 的超时时间(以秒为单位),超过指定的时长,Session就会被销毁。
  • 值为正数的时候,设定 Session 的超时时长。
  • 负数表示永不超时(极少使用)
  • public int getMaxInactiveInterval()获取 Session 的超时时间
  • public void invalidate() 让当前 Session
  • Session默认的超时时间为30min,因为在Tomcat服务器的配置文件web.xml中默认有配置
  • java中cookie和session cookie javaweb_java中cookie和session_29

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

java中cookie和session cookie javaweb_java中cookie和session_30

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

java中cookie和session cookie javaweb_html_31