cookie,session以及application的比较
cookie工作原理:

cookie代码:
1 @WebServlet(value = "/cookie",name = "CookieServlet")
2 public class CookieServlet extends HttpServlet {
3
4 @Override
5 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
6 String username=req.getParameter("username");
7 String password=req.getParameter("password");
8 //String expire=req.getParameter("expire");//获取前端传入多久之内自动登录
9
10 //创建cookie对象将我们的用户名以及密码设置到cookie中
11 Cookie usernameCookie=new Cookie("username",username);
12 //给cookie设置过期的时间,其单位是秒 10秒后下面的测试类就拿不到我们的用户名以及密码了
13 usernameCookie.setMaxAge(10);
14
15 Cookie passwordCookie=new Cookie("password",password);
16 passwordCookie.setMaxAge(10);
17
18 //cookie的响应
19 resp.addCookie(usernameCookie);
20 resp.addCookie(passwordCookie);
21
22 }
23 }
浏览器里面的记录:

测试类:
1 @WebServlet(value = "/cookieTest",name = "CookieTestServlet")
2 public class CookieTestServlet extends HttpServlet {
3 @Override
4 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
5
6 //获取所有的cookie的信息
7 Cookie[]cs=req.getCookies();
8
9 if(cs!=null){
10 for (Cookie c:cs){
11 System.out.println(c.getName()+"===="+c.getValue());
12 }
13 }
14
15 }
后台拿到的记录:


Session(会话)对象出现的原因:是因为HTTP协议是一个无状态的协议。
比如你登录淘宝 当你登录到自己的账号的时候无论你点击哪个标题页面 都会有你的淘宝用户名
流程:

代码:
1 @WebServlet(value = "/session",name = "SessionServlet")
2 public class SessionServlet extends HttpServlet {
3
4 @Override
5 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
6
7 User user=new User();
8 user.setId(1);
9 user.setName("张三");
10
11 //通过请求去获取session
12 HttpSession session=req.getSession();
13 session.setAttribute("user",user);
14
15 }
16 }
然后在每一个servlet里面都加上:



然后在浏览器里面先运行:

把控制台清除,然后访问不同的servlet都可以得到:

还有在浏览器第一次访问session的时候没有 当再访问其他的servlet的时候就会出现sessionID:

注意:如果浏览器关闭后,再打开浏览器访问我们的session那么我们的浏览器会重新弄个sessionID给你,不关浏览器就不会改变。
application:

说白了他在整个服务器就一个值
先在context里面设置我们的用户姓名:
1 @WebServlet(value = "/context",name = "ContextServlet")
2 public class ContextServlet extends HttpServlet {
3
4 @Override
5 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
6 ServletContext servletContext=req.getServletContext();
7 servletContext.setAttribute("name","王五");
8 }
9 }
然后再其他的servlet里面获取我们的姓名:
1 /**
2 * 在往后的登录过程中, 登录成功后都会将用户的个人信息放置到session中。
3 */
4 @WebServlet(value = "/login",name = "LoginServlet")
5 public class LoginServlet extends HttpServlet {
6
7 @Override
8 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
9
10 String username = req.getParameter("username");
11 String password = req.getParameter("password");
12
13 // select * from user where username = ? and password = ?
14 User user = new User();
15 user.setName(username);
16 user.setId(34);
17
18 req.getSession().setAttribute("user", user);
19
20 // 获取全应用唯一的一个 ServletContext类型的对象,单例
21 ServletContext servletContext = req.getServletContext();
22 System.out.println(servletContext.getAttribute("name"));
23
24 }
25 }
然后在浏览器里面先把context跑起来在运行其他的servlet在后台你会看见:


直接访问我们的jsp页面也可以:


总结:
cookie 是客户端(浏览器)存储。
session是服务器端存储的。
application 是ServletContext类型的对象,全局就唯一一个。无论是通过何种API,拿到的都是同一个对象。
cookie,session以及application的比较的更多相关文章
- Servlet学习笔记(1)--第一个servlet&&三种状态对象(cookie,session,application)&&Servlet的生命周期
servlet的404错误困扰了两天,各种方法都试过了,翻书逛论坛终于把问题解决了,写此博客来纪念自己的第一个servlet经历. 下面我会将自己的编写第一个servlet的详细过程提供给初学者,大神 ...
- c# Cookie,Session,Application,Cache 四种缓存使用情景
好记性不如烂笔头,记录一下C#缓存使用的情景模式....个人理解,不正之处,欢迎指正 讨论 Cookie,Session,Application,Cache 四种,有的缓存情景对人,有的缓存情景对事儿 ...
- Asp.net 中ViewState,cookie,session,application,cache的比较
Asp.net 中的状态管理维护包含ViewState,cookie,session,application,cache五种方式,以下是它们的一些比较: 1.存在于客户端还是服务端 客户端: view ...
- JavaWeb -cookie&session&application
cookie&session&application总结 Cookie[key-value](不是内置对象必须new): 1. Cookie 是由服务端生成的,在发送给客户端保存 2. ...
- 浅谈JS中的!=、== 、!==、===的用法和区别 JS中Null与Undefined的区别 读取XML文件 获取路径的方式 C#中Cookie,Session,Application的用法与区别? c#反射 抽象工厂
浅谈JS中的!=.== .!==.===的用法和区别 var num = 1; var str = '1'; var test = 1; test == num //tr ...
- cookie、session和application都是些什么神?——图文加案例,不怕你不会,就怕你不看
cookie.session和application都是些什么神? 前言: 一直想写一篇关于cookie和session的博客,由于种种原因,一直没有整理,这不,今天还就遇到问题了,之前虽然会,但是好 ...
- 了解ASP(三) -- Cookie, Session, Application
ASP一共内建了7个对象,有Session.Application.Cookie.Response.Request.Server,这些对象都可以直接使用. 1. 什么是 Cookie? 1. cook ...
- cookie session URL重写 与考试
状态管理.Cookie.Session.URL重写 HTTP协议:无状态的连接(每次连接都是新的请求)1.隐藏字段 <input type="hidden" name=&qu ...
- servlet三大作用域:request,session,application
javaweb开发中Servlet三大域对象的应用(request.session.application(ServletContext)). 1. request request是表示一个请求,只要 ...
- Session、Application、Cache
[Asp.Net]状态管理(Session.Application.Cache) 上篇博文介绍了在客户端状态管理的两种方式:http://www.cnblogs.com/wolf-sun/p/3329 ...
随机推荐
- JavaScript的标准库
Object 对象 概述 JavaScript 的所有其他对象都继承自Object对象,即那些对象都是Object的实例. Object对象的原生方法分成两类:Object本身的方法与Object的实 ...
- 在 Go 中恰到好处的内存对齐
问题 type Part1 struct { a bool b int32 c int8 d int64 e byte } 在开始之前,希望你计算一下 Part1 共占用的大小是多少呢? func m ...
- 小程序和APP抓包的问题
小程序和APP抓包的问题 很多同学都会遇到小程序和APP抓不到包的问题,抓不到https请求包,这边给大家提供一些解决方案. Yakit工具 首先需要的就是一个抓包神器yakit,这个工具非常好用强大 ...
- 如何学习 ROS+PX4
博客地址:https://www.cnblogs.com/zylyehuo/ 参考 https://www.bilibili.com/video/BV1vx4y1Y7Tu?spm_id_from=33 ...
- 什么是 IPv6,为什么我们还未普及?
在大多数情况下,已经没有人一再对互联网地址耗尽的可怕境况发出警告,因为,从互联网协议版本 4(IPv4)的世界到 IPv6 的迁移,虽然缓慢,但已经坚定地开始了,并且相关软件已经到位,以防止许多人预测 ...
- Linux如何从命令行卡死的进程中退出?
Linux如何从命令行卡死的进程中退出? 不知道大家在使用Linux的时候,会不会遇到一些命令,有可能卡顿,有可能执行时间过长(比如使用 find 查找某个文件),这个时候我不想继续执行这个命令了,说 ...
- BFS 2025/1/16
BFS Basic 主要特点:空间复杂度较高,基于队列 经常用于求最优解的搜索题 经典模型:连通块,最短迷宫路径,曼哈顿距离 Question 01 [ACP2056 山峰与山谷] 主体是广搜模板 难 ...
- php文件和文件夹操作类
文件和文件夹操作 移动 | 复制 | 删除 | 重命名 | 下载 <?php namespace Framework\Tools; use PharData; class FileManager ...
- List集合--java进阶day09
1.List集合 以下面的例子来解释存储有序和存储重复 如上图,我们是怎么添加这些字符串的,打印的时候就是按照这个顺序打印的--存取有序 并且"张三"出现了两次,也存入了两次--存 ...
- 【Ubuntu】在Ubuntu上配置Java环境
[Ubuntu]在Ubuntu上配置Java环境 壹.前言 Java是运用得非常广泛的编程语言,在使用Linux时难免会碰到需要用到JDK的情况,故本文介绍如何在Ubuntu上配置Java21环境. ...