Session与Cookie的原理以及使用小案例>从零开始学JAVA系列
Session与Cookie的原理以及使用小案例
Cookie和Session所解决的问题
都是用来解决HTTP的无状态问题,由于HTTP每一次请求都相当于不同的用户向服务器发送请求。HTTP协议无法记住浏览器端是不是同一个用户。Cookie和Session都是为了解决一个用户的多次请求之间数据的共享问题,只是实现原理不同,只能实现一个用户多个请求之间的数据共享。
Session与Cookie的原理
Cookie的原理
- 数据是存储在浏览器端的,服务器负责生成Cookie并设置好规则(可访问的路径、过期时间),然后响应给浏览器。
- 浏览器在收到响应的Cookie后,服务器指定的规则内请求服务器端,都会携带上该Cookie
- 服务器则可以通过读取request请求对象中的Cookie信息来进行用户身份的识别等...
提示:
第一次请求时,浏览器没有Cookie信息携带,而是由服务器响应Cookie给浏览器
第2次请求及其之后的请求,浏览器会携带Cookie信息向服务器发送请求(满足Cookie规则的情况)
特点:服务器压力小,不用存储任何数据,但是一旦浏览器的Cookie信息清除后,再向服务器发送请求时,相当于一个新的用户。
Cookie的失效时机
- 当浏览器的Cookie过期时(默认Cookie过期时间为一个会话,浏览器关掉就没了)
- 当服务器响应中设置cookie过期时间为0时
- 当浏览器的Cookie被清空时
小提示
当浏览器的Cookie的过期时间还没到时,如果浏览器没有清空Cookie,那么就算关掉浏览器,Cookie也依然存在。
Session的原理
- 数据是存储在服务器端的,服务器端通过浏览器请求中名为SessionID的Cookie来识别用户
提示: - 浏览器第一次请求服务器时,就会在服务器端开辟一片空间,其中有sessionId,浏览器会响应一个名为SessionID的Cookie设置到浏览器中
- 当浏览器第二次以及往后的请求时,每次向服务器发送的请求都会携带这个名为SessionId的Cookie
- 服务器就是以该Cookie来识别用户的,以该SessionID去对应的那一片内存空间获取数据。
- 只能解决单个用户的多个请求
Seesion的失效时机(仅在一个会话当中)
- 服务器清空Session:Session.invalidate()
- 超过Session过期时间未活动,在tomcat的conf目录的web.xml中可以看到配置的时间,默认为30分钟(可以在web服务器的web.xml中配置)
<session-config>
<session-timeout>30</session-timeout>
</session-config>
- 更改当前项目的当前session的失效时间,单位为秒
session.setMaxInactiveInterval(10);
- 当用户将浏览器关闭时。(其实这并没有真正的使服务器的session失效)
解释:由于浏览器向服务器第二次请求以后,都会携带名叫SeesionId的Cookie,而关闭掉了浏览器时,Cookie就被清除了。所以再向服务器访问时,就相当于一个新的用户,服务器会重新在内存中开辟一片空间,其空间通过生成的SessionId访问,并把这个新的SessionId响应给浏览器。
第一次请求

第二次请求及其之后的请求

小提示
即使使用了req.getSession().setMaxInactiveInterval(1000);设置了session的过期时间,浏览器在关闭时,也会清空session的Cookie。这个设置过期时间是针对服务器端的,到了过期时间,服务器就会销毁该session。
Cookie 和 Session的区别
- Cookie保存在客户端,Session保存在服务器端(SessionId可以通过Cookie保存在浏览器,也可以通过重写URL的方式获得)
- Cookie安全性不高,用户可以通过浏览器直接看到Cookie信息,可以仿造Cookie(可以加密Cookie),Session较为安全
- Session会在一定的时间保存在服务器中,如果访问量增多,考虑性能时,可以考虑使用Cookie
- 单个Cookie在客户端的大小限制是3k,也就是一个站点在客户端保存的数据不能超过3K。而Seesion可以保存任意类型的数据(javaBean等)
Cookie与Session的使用场景及小案例
- Cookie :记住我、网页皮肤、最近浏览商品
- Session:登录的用户信息、购物车(也可以用Cookie)
实现登录的记住我功能
LoginServlet
package com.it.servlet;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
@WebServlet(urlPatterns = "/Login")
public class LoginServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String username = req.getParameter("username");
String password = req.getParameter("password");
String readme = req.getParameter("readme");
// 判断用户名和密码是否为空
if("".equals(username) || "".equals(password)){
req.setAttribute("errorMsg","用户名和密码不能为空!");
req.getRequestDispatcher("/index.jsp").forward(req, resp);
return;
}
//1、创建Cookie
Cookie cookie1 = new Cookie("username", username);
Cookie cookie2 = new Cookie("password", password);
// 2、设置Cookie的访问规则, / 当前服务器有效,req.getContextPath() 当前项目有效
cookie1.setPath("/");
cookie2.setPath("/");
// 如果用户点击了readme,则设置Cookie的过期时间为1小时
if(readme != null) {
// 3、设置过期时间为1个小时
cookie1.setMaxAge(60 * 60);
cookie2.setMaxAge(60 * 60);
}else {
// 未点击readme,将cookie时间直接设置为过期
cookie1.setMaxAge(0);
cookie2.setMaxAge(0);
}
// 4、响应给浏览器
resp.addCookie(cookie1);
resp.addCookie(cookie2);
//5、跳转到登录成功页面
resp.sendRedirect(req.getContextPath() + "/success.jsp");
}
}
index.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<%
String path = request.getContextPath();
String username = "";
String password = "";
// 如果Cookie中没有值,则为空,有值的话设置为checked,让记住我的按钮动态选中
String readme = "";
Cookie[] cookies = request.getCookies();
if (cookies!=null) {
for (Cookie cookie : cookies) {
if (cookie.getName().equals("username")) {
username = cookie.getValue();
readme = "checked";
}
if (cookie.getName().equals("password")) {
password = cookie.getValue();
}
}
}
%>
<base href="<%=path%>/">
</head>
<body>
<center>
<form action="Login">
<p>用户名:<input type="text" name="username" value="<%=username%>"></p>
<p>密码:<input type="text" name="password" value="<%=password%>"></p>
<p><input type="checkbox" name="readme" <%=readme%> >记住我</p>
<p><input type="submit" value="点击登录"></p>
</form>
</center>
</body>
</html>
Servlet中获取Session并且设置值,以及JSP中获取Session中的数据
// Servlet的service方法中设置值
req.getSession().setAttribute("username",username);
// jsp中获取值,2种方式
sessionId为:<%=session.getId()%>
用户名为:${sessionScope.username}
用户名为:<%=session.getAttribute("username")%>
Session与Cookie的原理以及使用小案例>从零开始学JAVA系列的更多相关文章
- JAVAWEB - Servlet原理及其使用>从零开始学JAVA系列
目录 Servlet原理及其使用 什么是Servlet Servlet的使用 编写一个Servlet,使用继承HttpServlet的方式 配置web.xml 很简单的几个JSP文件 小提示,如果继承 ...
- JSP的执行原理、JSP的内置对象、四大作用域解析、MVC模式理解>从零开始学JAVA系列
目录 JSP的执行原理.JSP的内置对象.四大作用域解析.MVC模式理解 JSP的执行原理 这里拿一个小例子来解析JSP是如何被访问到的 首先将该项目部署到tomcat,并且通过tomcat启动 通过 ...
- Session和Cookie的原理
1.session和cookie的存储 session一般保存在服务端文件中,php.ini中有个配置项--session.save_path='';这个里面填写的路径,将会使session文件保存在 ...
- Session和Cookie的原理,以及在分布式应用中出现的问题和解决方案
产生原因 由于http协议是无状态的,同一个浏览器对服务器的两次请求之间是没有关系的,服务器认为两次请求都是全新的请求,不会记住上次请求成功的数据.然而现有的业务常常需要服务器能记住用户的访问情况, ...
- session和cookie工作原理说明
session 第一次请求: session_start 1.第一次发送http请求,由于第一次未携带session_id ,首先自动生成一个session_id,初始化$_SESSION[]; 2. ...
- 从零开始学java(小游戏 石头剪刀布)
Game.java package com.java;import java.util.Scanner;public class Game { private Player player ...
- [转]ASP.Net篇之Session与Cookie
本文转自:http://www.cnblogs.com/japanbbq/archive/2011/08/31/2160494.html Session: Session是“会话”的意思,然而,因为h ...
- 知识记录——Session与Cookie
Session: Session是“会话”的意思,然而,因为http协议是无状态的,那么每次客户端请求服务器端,服务器端都会以“崭新”的页面展示给客户端,这在静态的html页面中是不会存在任何影响,但 ...
- 浅析Django之session与cookie
浅析Django之session与cookie 1 session与cookie概述 原理: 由于HTTP协议是无状态,无连接的,当用户发起网路请求时,需要服务端能标识用户ID,用以存储用户相关信息, ...
随机推荐
- SqlServer中offset..fetch 的使用问题
好久没更新了,最近忙的很,也生病了,重感冒,555~~~ 早上抽的一丝空闲,来讲讲SqlServer中的分页问题.其实用过了多种数据库,分页这问题已经是老生常谈的问题了.不管是开发什么类型的网站,只要 ...
- AnyCast技术
在公司项目经历过DDoS攻击后,选用了一些比较成熟的DDoS防护厂商,在学习过程中,发现,许多DDoS厂商的防护技术都离不开 Anycast网络. 所以在这里整理一下AnyCast的相关资料. 1. ...
- 11、linux的目录结构
11.1.查看磁盘的id: blkid 11.2.linux目录类似一个倒挂的树: / 是所有目录的顶点,目录磁盘和分区是没有关联的,因此/下不同的目录会对应不同的磁盘的不同的分区: linux中硬盘 ...
- 10、linux启动过程
(1)linux启动说明: 第一步:开机自检,检查硬件,加载BIOS(帮我们找到启动盘是谁): 第二步:读取MBR(读取启动硬盘0柱面0磁道1扇区(512字节)的前446字节,找到装有操作系统的分区) ...
- CSS水平居中与垂直居中的方法
一.水平居中 1.行内元素水平居中 在父元素里添加text-align:center即可.代码如下: <style> .container-1 { height: 50px; border ...
- gRPC四种模式、认证和授权实战演示,必赞~~~
前言 上一篇对gRPC进行简单介绍,并通过示例体验了一下开发过程.接下来说说实际开发常用功能,如:gRPC的四种模式.gRPC集成JWT做认证和授权等. 正文 1. gRPC四种模式服务 以下案例演示 ...
- Zookeeper:Windows下Zookeeper启动zkServer.cmd闪退问题
Zookeeper在Windows下启动只需要运行zkServer.cmd双击即可(需保证运行环境中正确安装了Java运行环境) 但是在有的时候会出现双击闪退的情况.针对闪退,可按照如下方法进行解决: ...
- MySQL 数据排序 order by
1.单一字段排序 select * from tablename order by field1 desc; 排序采用order by+排序字段 升序关键字(asc,desc),排序字段可以放多个,多 ...
- 你会用哪些JavaScript循环遍历
总结JavaScript中的循环遍历定义一个数组和对象 const arr = ['a', 'b', 'c', 'd', 'e', 'f']; const obj = { a: 1, b: 2, c: ...
- 「HEOI2016/TJOI2016」排序
「HEOI2016/TJOI2016」排序 题目大意 给定一个 \(1\) 到 \(n\) 的排列,每次可以对这个序列的一个区间进行升序/降序排序,求所有操作后第 \(q\) 个位置上的数字. 题解 ...