iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >JavaWeb之会话技术的示例分析
  • 794
分享到

JavaWeb之会话技术的示例分析

2023-06-20 17:06:45 794人浏览 八月长安
摘要

这篇文章给大家分享的是有关javaweb之会话技术的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。会话技术    1. 会话:一次会话中包含多次请求和响应

这篇文章给大家分享的是有关javaweb之会话技术的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

会话技术

    1. 会话:一次会话中包含多次请求和响应。

           一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止

    2. 功能:在一次会话的范围内的多次请求间,共享数据

    3. 方式:

          1. 客户端会话技术:Cookie

          2. 服务器端会话技术:Session

Cookie:

1. 概念:客户端会话技术,将数据保存到客户端

2. 快速入门

            1. 创建Cookie对象,绑定数据

                 new Cookie(String name, String value) 

            2. 发送Cookie对象

                 response.addCookie(Cookie cookie) 

            3. 获取Cookie,拿到数据

                 Cookie[]  request.getCookies()  

3. 实现原理

             基于响应头set-cookie和请求头cookie实现

4.注意事项:

              1.一次可以发送多个cookie。可以创建多个Cookie对象,使用response调用多次addCookie方法发送cookie即可。

              2. cookie在浏览器中保存的保存时间。使用setMaxAge(int seconds)方法可以将Cookie数据写到硬盘的文件中,并指定cookie存活时间

              3. 默认情况下一个Tomcat服务器中,部署了多个WEB项目,那么在这些web项目中cookie不能共享。如果要共享通过setPath(String path)设置当前虚拟目录:path设置为"/"

              4. 不同的tomcat服务器间cookie共享问题?使用setDomain(String path)方法:如果设置一级域名相同,那么多个服务器之间cookie可以共享

5. Cookie的特点和作用

        1. cookie存储数据在客户端浏览器

        2. 浏览器对于单个cookie 的大小有限制(4kb) 以及 对同一个域名下的总cookie数量也有限制(20个)

        a. cookie一般用于存出少量的不太敏感的数据

        b. 在不登录的情况下,完成服务器对客户端的身份识别

代码实现

//记录电脑上次打开网页的时间 @WebServlet("/CookieTest")public class CookieTest extends httpservlet {    @Override    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {        //设置响应体格式与编码        resp.setContentType("text/html;charset=utf-8");        //获取cookie        Cookie[] cookies = req.getCookies();        boolean flag=false;        //遍历cookie数据        if (cookies!=null && cookies.length>0){            for (Cookie cookie : cookies) {                String name = cookie.getName();                //判断名称中是否有:lastTime                if ("lastTime".equals(name)){                    //设置Cookie的value,下一次使用                    flag=true;                    Date date=new Date();                    SimpleDateFORMat sdf=new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");                    String str_date = sdf.format(date);                    //tomcat不支持特殊字符,需要通过URL编码                    System.out.println("编码前 "+str_date);                    str_date=URLEncoder.encode(str_date,"utf-8");                    System.out.println("编码后"+str_date);                     //新值串回去,设置存活时间                    cookie.setValue(str_date);                    cookie.setMaxAge(60*60*24);                    resp.addCookie(cookie);                    //有,欢迎光临,上次登录时间                    String value = cookie.getValue();                    //URL 解码                    value=URLDecoder.decode(value,"utf-8");                    resp.getWriter().write("<h2>欢迎回来,您上一次的访问时间是:"+value+"</h2>");                    break;                }            }        }        if (cookies==null || cookies.length==0 || flag==false){            //第一次访问            Date date=new Date();            SimpleDateFormat sdf=new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");            String str_date = sdf.format(date);             //tomcat不支持特殊字符,需要通过URL编码            System.out.println("编码前 "+str_date);            str_date=URLEncoder.encode(str_date,"utf-8");            System.out.println("编码后"+str_date);             Cookie cookie=new Cookie("lastTime",str_date);            //新值串回去,设置存活时间            cookie.setValue(str_date);            cookie.setMaxAge(60*60*24);            resp.addCookie(cookie);             resp.getWriter().write("<h2>您好,欢迎您首次访问</h2>");        }     }  }

Session:

1. 概念:服务器端会话技术,在一次会话的多次请求间共享数据,将数据保存在服务器端的对象中。HttpSession

2. 快速入门:

        1. 获取HttpSession对象:

            HttpSession session = request.getSession();

        2. 使用HttpSession对象:

            Object getAttribute(String name)  

            void setAttribute(String name, Object value)

            void removeAttribute(String name)  

3. 原理

           Session的实现是依赖于Cookie的。

4. 细节:

        1. 当客户端关闭后,服务器不关闭,两次获取session是否为同一个?

                默认情况下。不是。

                如果需要相同,则可以创建Cookie,键为jsESSIONID,设置最大存活时间,让cookie持久化保存。

                    Cookie c = new Cookie("JSESSIONID",session.getId());

                    c.setMaxAge(60*60);

                    response.addCookie(c);

        2. 客户端不关闭,服务器关闭后,两次获取的session是同一个吗?

            不是同一个,但是要确保数据不丢失。tomcat自动完成以下工作

                  session的钝化: 在服务器正常关闭之前,将session对象系列化到硬盘上

                  session的活化: 在服务器启动后,将session文件转化为内存中的session对象即可。

        3.session什么时候被销毁?

            1. 服务器关闭

            2. session对象调用invalidate() 。

            3. session默认失效时间 30分钟

5. session的特点

           1. session用于存储一次会话的多次请求的数据,存在服务器端

           2. session可以存储任意类型,任意大小的数据

代码实现

@WebServlet("/SessionDemo1")public class SessionDemo1 extends HttpServlet {    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {        //session        HttpSession session = request.getSession();        session.setAttribute("msg","hello session");        //请求转发(这个是在一个URL中)        request.setAttribute("reqmsg","hello req.session");        request.getRequestDispatcher("/SessionDemo3").forward(request,response);      }     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {            this.doPost(request,response);    }}  @WebServlet("/SessionDemo3")public class SessionDemo3 extends HttpServlet {    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {       //获取数据        HttpSession session = request.getSession();        Object msg = session.getAttribute("msg");        System.out.println(msg);        //请求转发        Object reqmsg = request.getAttribute("reqmsg");        System.out.println(reqmsg);    }     protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {            this.doPost(request,response);    }}

session与Cookie的区别:

         1.session存储数据在服务器端,Cookie在客户端

         2.session没有数据大小限制,Cookie有

         3.session数据安全,Cookie相对于不安全

         4.session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能,考虑到减轻服务器性能方面,应当使用cookie。

感谢各位的阅读!关于“JavaWeb之会话技术的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: JavaWeb之会话技术的示例分析

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaWeb之会话技术的示例分析
    这篇文章给大家分享的是有关JavaWeb之会话技术的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。会话技术    1. 会话:一次会话中包含多次请求和响应...
    99+
    2023-06-20
  • JavaWeb之会话技术案例详解
    会话技术     1. 会话:一次会话中包含多次请求和响应。          &...
    99+
    2024-04-02
  • JavaWeb会话技术详解与案例
    1.什么是会话: 2.会话技术有哪些: 什么是Cookie? Cookie,有时也用其复数形式 Cookies。类型为“小型文本文件”,是某些网站为了辨别用户身份,进行Sessi...
    99+
    2024-04-02
  • JavaWeb会话技术怎么用
    小编给大家分享一下JavaWeb会话技术怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.什么是会话:2.会话技术有哪些:什么是Cookie?Cookie,...
    99+
    2023-06-25
  • Javaweb会话跟踪技术Cookie和Session的具体使用
    目录前言一.会话引入二.Cookie1.Cookie的理解2.Cookie生命周期3.Cookie有效路径4.Cookie使用细节三.Session1.Session基本原理2.Se...
    99+
    2024-04-02
  • mongodb分片技术的示例分析
    这篇文章主要为大家展示了“mongodb分片技术的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mongodb分片技术的示例分析”这篇文章吧。在mong...
    99+
    2024-04-02
  • Hybrid App技术的示例分析
    这篇文章给大家分享的是有关Hybrid App技术的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。背景随着Web技术的发展和移动互联网的发展,Hybrid技术已经成为一种...
    99+
    2024-04-02
  • 区块链技术的示例分析
    这篇文章给大家分享的是有关区块链技术的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。区块链技术最初源于解决“拜占庭将军”问题,金融科技的发展使得区块链技术有了更好的应用场...
    99+
    2024-04-02
  • ajax请求技术的示例分析
    这篇文章主要为大家展示了“ajax请求技术的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ajax请求技术的示例分析”这篇文章吧。1.写在前面:阅读要求...
    99+
    2024-04-02
  • Hadoop技术创新的示例分析
    这篇文章将为大家详细讲解有关Hadoop技术创新的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。如今有很多公司都在努力挖掘他们拥有的大量数据,包括结构化、非结构化、半结构化以及二进制数据等,来探索...
    99+
    2023-06-02
  • SEO优化技术的示例分析
    这篇文章给大家分享的是有关SEO优化技术的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。如何设置SEO关键词当然重要,但SEO优化技术如果只是机械式的说该做什麽不做什麽,而涉及的步骤又非常死板,例如:将焦...
    99+
    2023-06-10
  • C++中traits技术的示例分析
    这篇文章主要介绍了C++中traits技术的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Traits编程技法  让我们一点点抛出问题,然后一点点深入。  1. 首先...
    99+
    2023-06-15
  • Redis主从技术的示例分析
    这篇文章主要为大家展示了“Redis主从技术的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Redis主从技术的示例分析”这篇文章吧。Redis复制在生产环境中,Redis通过持久化功能...
    99+
    2023-06-27
  • Android热修复技术原理之资源热修复技术的示例分析
    小编给大家分享一下Android热修复技术原理之资源热修复技术的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、普遍的实现方式目前市面上的很多资源热修复...
    99+
    2023-06-20
  • layer.js之回调销毁对话框的示例分析
    这篇文章给大家分享的是有关layer.js之回调销毁对话框的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。layer.js弹出层给我们封装了基本的销毁按钮,如图所示:当我...
    99+
    2024-04-02
  • 修复shiro固定会话攻击漏洞的示例分析
    修复shiro固定会话攻击漏洞的示例分析,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。固定会话攻击(session fixation attack)是通过给被攻击人一个带s...
    99+
    2023-06-26
  • Css技术中height属性的示例分析
    这篇文章主要介绍了Css技术中height属性的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、height1、height:10...
    99+
    2024-04-02
  • Oracle 12c R2中ADG会话保留特性的示例分析
    这篇文章给大家分享的是有关Oracle 12c R2中ADG会话保留特性的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Oracle 12c R2中有一个不错的特性,那就...
    99+
    2024-04-02
  • 数据库恢复技术的示例分析
    小编给大家分享一下数据库恢复技术的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!数据库恢复...
    99+
    2024-04-02
  • Linux虚拟化技术KVM的示例分析
    这篇文章主要介绍Linux虚拟化技术KVM的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!KVM是一种内建于 Linux&reg; 中的开源虚拟化技术。具体而言,KVM 可帮助您将 Linux 转变为...
    99+
    2023-06-27
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作