返回顶部
首页 > 资讯 > 精选 >JavaWeb核心技术中Session与Cookie怎么使用
  • 697
分享到

JavaWeb核心技术中Session与Cookie怎么使用

2023-07-05 05:07:26 697人浏览 安东尼
摘要

本篇内容介绍了“javaweb核心技术中Session与Cookie怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!会话会话:用户打开

本篇内容介绍了“javaweb核心技术中Session与Cookie怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

    会话

    会话:用户打开浏览器进行的一系列操作直至关闭浏览器的过程看作是一次会话

    Http协议是无状态的,不能实现跟踪对话。比如进入一个网站,每次操作的请求之间相互独立,无法相互联系。也就是说你每次请求过后得到的服务器响应或者数据无法被保存。

    跟踪会话的两种技术:

    • 就服务端来讲,采用Session技术。服务器为每一个用户创建了一个唯一的Session标识用于跟踪和管理该用户的资源。用户在下次提交请求时会一并提交Session标识用于服务器识别然后记录该用户的状态

    • 客户端,Cookie技术。Cookie也叫做硬盘Cookie,因为Cookie存储在每一个客户端的硬盘之上。用户在第一次访问服务器时,由服务器通过响应头的方式将用户cookie传递给浏览器。之后的访问会将请求与cookie一并提交

    • 在理解上:Session可以看作是服务器对于该用户的标记,而cookie是位于客户端的标识,客户提交请求时一并提交cookie,服务器将会根据客户的cookie找到对应的session标识从而实现跟踪会话

    当用户关闭浏览器后,对应的Cookie标识也会随即销毁,但此时服务器端session并未失效,只是由于cookie销毁后无法继续跟踪用户会话

    Cookie

    曲奇饼干

    理解为:用户的信件 也可以理解为该用户的标志 由用户携带

    用户向服务器发送的请求当中会包含该cookie

    而浏览器也会根据该cookie判断该用户是否访问过本网站从而得知该用户的数据是否已经存在

    使用过的cookie会保存在本地的用户目录下

    cookieapi

    // 上面提到过用户的请求会携带cookie  所以要从客户端获取到cookieCookie[] cookies = req.getCookies();// --返回Cookie数组// 创建cookie  两个参数  键name   --   值valueCookie cookie = new Cookie("LoginTimes",System.currentTimeMillis()+"");// 获取键cookie.getName()// 获取值cookie.getValue()// 设置Cookie有效期  --> 24*60*60表示24小时*60分钟*60秒cookie.setMaxAge(24*60*60);// 响应给客户端一个Cookie(信件)resp.addCookie(cookie);

    cookie示例–> 浏览器显示用户上次的访问时间

    // 参考下方的doGet方法体{        // -- 显示上次访问的时间        req.setCharacterEncoding("UTF-8");        resp.setCharacterEncoding("UTF-8"); resp.setHeader("contenttype","text/html;charset=UTF-8");System.out.println("resp编码:"+resp.getCharacterEncoding());        System.out.println("req编码:"+req.getCharacterEncoding());        PrintWriter out = resp.getWriter();        // 从客户端获取Cookie        Cookie[] cookies = req.getCookies();// --返回Cookie数组        // 判断该用户是否已经存在Cookie        if (cookies!=null){            out.write("LastTime Login Time:");            for (Cookie cookie : cookies) {                // 遍历找到访问时间的Cookie  getName获得cookie中的键                if (cookie.getName().equals("LoginTimes")){                    // 获取LoginTimes-Cookie的值  -- value                    long l = Long.parseLong(cookie.getValue());                    Date date = new Date(l);                    out.write(date.toLocaleString());                }            }        }        // 记录本次访问的时间  --> 新建Cookie        Cookie cookie = new Cookie("LoginTimes",System.currentTimeMillis()+"");// 设置Cookie有效期  --> 24*60*60表示24小时*60分钟*60秒        cookie.setMaxAge(24*60*60);        // 响应给客户端一个Cookie(信件)        resp.addCookie(cookie);    }

    编码问题

    如下代码所示

    // setCharacterEncoding意思是在程序中将请求和响应均置为utf-8编码 但是可能浏览器会无法解析        req.setCharacterEncoding("UTF-8");        resp.setCharacterEncoding("UTF-8");// 浏览器使用的编码集可能与UTF-8不同  所以此处设置浏览器采用UTF-8编码        resp.setHeader("content-type","text/html;charset=UTF-8");

    但是我们在想要使cookie的值为中文汉字时,建议使用URLEncoder/URLDncoder

    // 编码URLEncoder.encode("张三","utf-8");// 解码URLDecoder.decode("李四","utf-8");

    删除cookie

    resp.setMaxAge(0);

    网页中查看cookie

    • 首先打开浏览器页面审查元素 选中网络

    • 在地址栏中执行对应操作

    • 然后在审查元素->网络中会看到我们的请求数据包

    • 点击该数据包即可查看所有信息

    JavaWeb核心技术中Session与Cookie怎么使用

    以上述显示登录时间为例 可以看到此处的Cookie 有一个LoginTime对应的值

    还可以点击应用选中cookie即可查看所有的cookie属性

    JavaWeb核心技术中Session与Cookie怎么使用

    Session

    会话

    一个Session独占一个浏览器,一个浏览器对应一个Session(同一用户在不同浏览器登录,使用的session是不同的),浏览器未关闭Session就一直存在

    用户登录网站成功之后会分到一个SessionID,至此,用户在该网站执行何种操作都无需再次登录,因为在提交请求时服务器会识别用户session然后在此session之下响应用户请求

    Session存放在服务器,用户实际拿到的是SessionID

    SessionAPI

    // Session对象httpsession session = req.getSession();// session创建时间out.write("创建时间:"+session.getCreationTime()+"\n");// sessionID获取out.write("SessionID:"+session.getId()+"\n");// session上次访问时间out.write("上次访问时间:"+session.getLastAccessedTime()+"\n");// setAttribute设置键值属性  getAttribute根据键获取值// getValue 根据键获取值-->从2.2开始呗getA他tribute替代// removeAttribute(String name) 删除name键绑定的对象 如果不存在则不执行任何操作// isNew() 判断该Session是否为新创建的//注销Session  session.invalidate();//注销Session也会注销掉SessionID

    Session使用->servlet交互数据

    Session不仅可以传输String类型还可以传输对象

    // Servlet 1protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        // 编码问题        req.setCharacterEncoding("UTF-8");        resp.setCharacterEncoding("UTF-8");        resp.setHeader("content-type","text/html;charset:utf-8");        // 流        PrintWriter out = resp.getWriter();        // Session        // -- 1.获取Session对象        HttpSession session = req.getSession();        // -- 2.获取SessionID        String id = session.getId();        // -- 3.判断该ID是否存在        if (session.isNew()) {            out.write("SessionID已存在:"+id);        }else {            out.write("Session创建成功,ID:"+id);        }        out.write("<h2>数据已写出,跳转checkData查看</h2>");        // -- 4.写出数据        session.setAttribute("name","张三");    }// Servlet  2protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        // 编码        req.setCharacterEncoding("UTF-8");        resp.setCharacterEncoding("UTF-8");        resp.setHeader("content-type","text/html;charset=UTF-8");        // 获取数据        HttpSession session = req.getSession();        String name = (String) session.getAttribute("name");        // 写出数据        resp.getWriter().write("name:"+name);    }

    传输对象时只需将session.setAttribute("键", 值)中的值更改为对象即可

    JavaWeb核心技术中Session与Cookie怎么使用

    通过抓包发现,在用户第一次请求时会由服务器创建Session并存储为cookie的形式(jsESSIONID=你的SessionID),那么当用户提交请求时(我们已经知道Cookie会被一起提交),所以此时服务器也会获取到你的Session,因此你的请求操作都将会在同一Session中执行。等同于服务器识别到了你的Session你就拥有了某种权限

    Session与Cookie

    Session保存在服务器端,当用户量过多时就可能会出现服务器过载现象。所以开发时也需要提前避免,所以通常利用Session+Cookie使用来减轻服务器压力。重要信息保存在Session中,其他信息可以用Cookie保存

    Cookie单个能保存的最大数据量为4kb,通常一个浏览器站点只允许存在20个cookie是把用户数据写到用户浏览器,浏览器保存

    Session是把用户数据写到用户的独占Session中

    Session相对于cookie使用频率更高,更加方便。cookie只能用于存储字符串(以键值对的形式)并且可存放数据有限,而Session可以存储对象

    “JavaWEB核心技术中Session与Cookie怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

    --结束END--

    本文标题: JavaWeb核心技术中Session与Cookie怎么使用

    本文链接: https://lsjlt.com/news/349708.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • JavaWeb核心技术中Session与Cookie怎么使用
      本篇内容介绍了“JavaWeb核心技术中Session与Cookie怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!会话会话:用户打开...
      99+
      2023-07-05
    • JavaWeb核心技术中Session与Cookie浅析
      目录会话Cookie曲奇饼干cookieAPI编码问题删除cookie网页中查看cookieSession会话SessionAPISession与Cookie会话 会话:用户打开浏览...
      99+
      2023-02-22
      JavaWeb Session与Cookie JavaWeb Session JavaWeb Cookie
    • Javaweb会话跟踪技术Cookie和Session的具体使用
      目录前言一.会话引入二.Cookie1.Cookie的理解2.Cookie生命周期3.Cookie有效路径4.Cookie使用细节三.Session1.Session基本原理2.Se...
      99+
      2024-04-02
    • Java cookie和session会话技术怎么使用
      这篇文章主要介绍“Java cookie和session会话技术怎么使用”,在日常操作中,相信很多人在Java cookie和session会话技术怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希...
      99+
      2023-07-05
    • 核心技术:J2ME中RMS的使用解析(转)
      核心技术:J2ME中RMS的使用解析(转)[@more@]在J2ME中,RMS作为唯一的永久性存储工具,其重要性是不言而喻的。但是很多刚刚开始学习J2ME的新人总是抱怨在这方面的资料很少,或者是针对性不强。因此,我想把自己在这方面的一些学习...
      99+
      2023-06-03
    • JavaWeb会话技术怎么用
      小编给大家分享一下JavaWeb会话技术怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.什么是会话:2.会话技术有哪些:什么是Cookie?Cookie,...
      99+
      2023-06-25
    • J2ME平台中Cookie技术怎么用
      这篇文章给大家分享的是有关J2ME平台中Cookie技术怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Cookie技术在J2ME平台的应用与实现Cookie在Web应用程序...
      99+
      2024-04-02
    • 深入剖析Ajax技术:揭开其核心技术原理与应用
      深入了解Ajax技术:探索其核心技术原理与应用Ajax(Asynchronous JavaScript and XML)是一种在Web开发中广泛应用的技术,它通过使用异步通信和JavaScript的技术手段,实现了在不刷新整个网...
      99+
      2024-01-26
      ajax 技术原理 应用(应用案例 应用实践)
    • JavaWeb之Serverlet技术怎么应用
      Servlet是JavaWeb中的一种技术,它是运行在服务器上的Java程序,用于处理客户端的请求并生成相应的响应。以下是Servl...
      99+
      2023-10-19
      JavaWeb
    • 怎么解析RadonDB分布式数据库核心技术与实现
      怎么解析RadonDB分布式数据库核心技术与实现,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。摘要:随着数据规模的逐步扩大,存储和运维成本逐渐...
      99+
      2024-04-02
    • Laravel中不能使用COOKIE和SESSION怎么解决
      本篇内容主要讲解“Laravel中不能使用COOKIE和SESSION怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Laravel中不能使用COOKIE和SESSION怎么解决”吧!CO...
      99+
      2023-07-04
    • 禁用Cookie后继续使用session怎么实现
      这篇“禁用Cookie后继续使用session怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“禁用Cookie后继续使...
      99+
      2023-06-26
    • 计算机网络中因特网采用的核心技术是什么
      小编给大家分享一下计算机网络中因特网采用的核心技术是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!因特网采用的核心技术是TCP/IP协议。TCP/IP协议是在...
      99+
      2023-06-14
    • 开源分布式数据库RadonDB的核心技术与实现是怎样的
      开源分布式数据库RadonDB的核心技术与实现是怎样的,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。RadonDB是一款将分布...
      99+
      2024-04-02
    • Python 容器日志同步,探索数据同步的核心技术与应用
      在现代化的软件架构中,容器化技术已经成为了非常流行的一种方式。这种技术可以帮助我们快速构建、部署和管理应用程序。在容器化的环境中,日志同步是非常重要的一个环节。本文将会探讨 Python 容器日志同步的核心技术与应用。 一、容器日志同步的...
      99+
      2023-11-02
      容器 日志 同步
    • Linux操作系统存储子系统核心技术中的硬盘与RAID是什么意思
      这篇文章将为大家详细讲解有关Linux操作系统存储子系统核心技术中的硬盘与RAID是什么意思,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Linux操作系统的存储子系统应该是Linux中最为...
      99+
      2023-06-15
    • laravel的核心组件illuminate怎么使用
      本篇内容介绍了“laravel的核心组件illuminate怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!composer来安装La...
      99+
      2023-07-05
    • VUE Nuxt.js中间件的奥秘:掌握核心技术,打造卓越应用
      Nuxt.js 是一个基于 Vue.js 的通用框架,它允许开发人员轻松构建单页面应用程序 (SPA) 和静态网站。Nuxt.js 的一大优势在于其强大的中间件功能,它使开发人员能够在应用程序的不同层级轻松扩展其功能。 中间件的作用 中...
      99+
      2024-02-15
      Nuxt.js 中间件 应用程序 扩展 代码示例
    • CGI中怎么使用Cookie
      本篇内容介绍了“CGI中怎么使用Cookie”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!CGI中使用Cookie在 http 协议一个很大...
      99+
      2023-06-08
    • vue3中cookie怎么使用
      这篇“vue3中cookie怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue3中cookie怎么使用”文章吧。前...
      99+
      2023-07-06
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作