Servlet p5 Cookie对象

这篇具有很好参考价值的文章主要介绍了Servlet p5 Cookie对象。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Cookie对象

Cookie是浏览器提供的一种技术,通过服务器的程序能将一些只须保存在客户端,或者在客户端进行处理的数据,放在本地的计算机上,不需要通过网络传输,因而提高网页处理的效率,并且能够减少服务器的负载,但是由于Cook是服务器端保存在客户端的信息,所以其安全性也是很差的。例如常见的记住密码侧可以通过Cookie来实现。

有一个专门操作Cookie的类javax.servlet.http.Cookie,随着服务器端的响应发送给客户端,保存在浏览器。当下次再访问服务器时把Cookie再带回服务器。

Cookie的格式:键值对用 "=" 链接,多个键值对间通过";"隔开。

浏览器查看Cooki:

  1. Network -> Headers

    Servlet p5 Cookie对象

  2. Application -> Cookies

    Servlet p5 Cookie对象

Cookie的创建和发送

通过 new Cookie("key", "value") 来创建一个 Cookie对象,要想要将 Cookie 随响应发送到客户端,需要先添加到 response对象 中,response.addCookie(cookie) 此时该 cookie对象 会随着响应发送到客户端。在浏览器上可以看见。

代码演示:

@WebServlet("/cookie01")
public class Cookie01 extends HttpServlet {
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //创建Cookie
        Cookie cookie = new Cookie("name", "admin");
        //发送(响应)Cookie对象
        resp.addCookie(cookie);
    }
}

Cookie的获取

在服务器端只提供了一个 getCookies()的方法用来获取客户端传回的所有 cookie 组成的一个数组,如果需要获取单个 cookie 则需要通过遍历,getName()获取 Cookie 的名称,getValue() 获取 Cookie 的值。

代码演示:

@WebServlet("/cookie02")
public class Cookie02 extends HttpServlet {
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //获取Cookie数组
        Cookie[] cookies = req.getCookies();

        //判断是否为空
        if (cookies != null && cookies.length > 0){
            //遍历cookie数组
            for (Cookie cookie : cookies) {
                String name = cookie.getName();
                String value = cookie.getValue();
                System.out.println("名称 = " + name + "  值 = " + value);
            }
        }
    }
}

Cookie设置到期时间

除了Cookie的名称和内容外,我们还需要关心一个信息,到期时间,到期时间用来指定该cookie何时失
效。默认为当前测览器关闭即失效。我们可以手动设定cook的有效时间(通过到期时间计算),通过
setMaxAge(int time) 方法设定cookie的最大有效时间,以秒为单位。

到期时间的取值

  • 负整数

    若为负数,表示不存储该cookie。
    cookie的maxAge属性的默认值就是 -1,表示只在浏览器内存中存活。一旦关闭浏览器窗口,那么cookie就会消失。

  • 正整数
    若大于0的整数,表示存储的秒数。
    表示cookie对象可存活指定的秒数。当生命大于0时,浏览器会把Cookie保存到硬盘上,就算关闭浏览器,就算重启客户端电脑,cookie也会存活相应的时间。


  • 若为0,表示删除该cookie。
    cookie生命等于0是一个特殊的值,它表示cookie被作废!也就是说,如果原来浏览器已经保存了这个Cookie,那么可以通过Cookie的setMaxAge(0)来删除这个Cookie。无论是在浏览器内存中,还是在客户端硬盘上都会删除这个Cookie。

代码演示

@WebServlet("/cookie03")
public class Cookie03 extends HttpServlet {
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //负整数
        Cookie cookie = new Cookie("uname1", "No.1");
        cookie.setMaxAge(-1);
        resp.addCookie(cookie);

        //正整数
        Cookie cookie2 = new Cookie("uname2", "No.2");
        cookie2.setMaxAge(30);
        resp.addCookie(cookie2);

        //负整数
        Cookie cookie3 = new Cookie("uname3", "No.3");
        cookie3.setMaxAge(0);
        resp.addCookie(cookie3);
    }
}

Cookie的注意点

  1. Cookie保存在当前浏览器中。

    在一般的站点中常常有记住用户名这样的操作,该操作只是将信息保存在本机上,换电脑以后这些信息就无效了,而且Cookie不能跨浏览器。

  2. Cookie存中文问题

    Cookie 中不能出现中文,如果有中文则通过 URLEncoder.encode() 进行编码,获取时通过URLDecoder.decoder()进行解码。

  3. 同名Cookie问题

    如果服务器端发送重复的 Cookie,那么会覆盖原有的 Cookie。

  4. 浏览器存放的Cookie数量

    不同的浏览器对 Cookie 也有限定,Cookie的存储是有上限的。Cookie是存储在客户端(浏览器)的,而且一般是由服务器端创建和设定。后期结合 Session 来实现回话跟踪。

代码演示:

/**
 * @author: 86199
 * @date: 2023/6/28 20:56
 * Description:
 * Cookie的注意点:
 *  1. Cookie只能在当前浏览器中有效(不跨浏览器和电脑)
 *  2. Cookie不能存中文
 *     如果一定要存中文,则需要通过URLEncoder.encode()
 *  3. 如果出现同名的Cookie对象,则会覆盖
 *  4. Cookie的存储数量是有上限的,不同浏览器的上限不同,Cookie存储的大小是有效的,在4kb左右
 */

@WebServlet("/cookie04")
public class Cookie04 extends HttpServlet {
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //cookie存中文
        String name = "姓名";
        String value = "张三";

        //编码
        name = URLEncoder.encode(name);
        value = URLEncoder.encode(value);

        //创建Cookie对象
        Cookie cookie = new Cookie(name, value);

        //发送cookie
        resp.addCookie(cookie);

        //获取Cookie数组
        Cookie[] cookies = req.getCookies();

        //非空判断
        if (cookies != null && cookies.length > 0){
            //遍历
            for (Cookie i : cookies) {
                //解码
                System.out.println(URLDecoder.decode(i.getName()));
                System.out.println(URLDecoder.decode(i.getValue()));
            }
        }

        //将原来已有的cookie对象重新设置
        Cookie cookie2 = new Cookie("name", "张三");
        resp.addCookie(cookie2);
    }
}

Cookie 的路径

Cookie 的 setPath 设置 Cookie 的路径,这个路径直接决定了服务器的请求是否可以从浏览器中加载某些 Cookie。

  1. cookie.setPath("/");

    当前服务器下的任何项目资源都可以获取Cookie对象。

    /*当前项目路径为:s01*/
    Cookie cookie01 = new Cookie("cookie01", "cookie01");
    cookie01.setPath("/");
    resp.addCookie(cookie01);
    
  2. cookie.setPath("/当前项目");

    当前项目下的任意资源可以获取Cookie对象,默认值,可以不用设置。

    /*当前项目路径为:s01*/
    Cookie cookie02 = new Cookie("cookie02", "cookie02");
    cookie02.setPath("/sc04");
    resp.addCookie(cookie02);
    
  3. cookie.setPath("/指定项目(可以非当前项目)");

    指定项目下的资源可以获取 Cookie对象,只能在指定项目才能获取,就算是产生Cookie对象的项目也不行。

    /*当前项目路径为:s01*/
    Cookie cookie03 = new Cookie("cookie03", "cookie03");
    cookie03.setPath("/ser03");
    resp.addCookie(cookie02);
    
  4. cookie.setPath("/指定项目/指定资源");

    指定目录下的资源才可以获取Cookie对象

    /*当前项目路径为:s01*/
    Cookie cookie04 = new Cookie("cookie04", "cookie4");
    cookie01.setPath("/sc04/cookie02");
    resp.addCookie(cookie04);
    

如果我们设置path,如果当前访问的路径包含了cookie的路径(当前访问路径在cookie路径基础上要比cookie的范围小),cookie就会加载到request对象之中。

cookie的路径指的是可以访问该cookie的顶层目录,该路径的子路径也可以访问该cookie。

总结:当访问的路径包含了 cookie 的路径时,则该请求将带上该cookie;如果访问路径不包含cookie路径,则该请求将不会带上该cookie。文章来源地址https://www.toymoban.com/news/detail-515736.html

到了这里,关于Servlet p5 Cookie对象的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 利用远程调试获取Chromium内核浏览器Cookie

    本文将介绍不依靠DPAPI的方式获取Chromium内核浏览器Cookie 首先我们以edge为例。edge浏览器是基于Chromium的,而Chromium是可以开启远程调试的,开启远程调试的官方文档如下: https://blog.chromium.org/2011/05/remote-debugging-with-chrome-developer.html 那么开启远程调试以后可以做什么呢,继续看

    2024年02月15日
    浏览(34)
  • 【Vue】浏览器缓存sessionStorage、localStorage、Cookie

    目录 一、sessionStorage 1、简介 2、方法 3、代码示例 a、存取单个数据 b、存取对象 c、清除数据 二、localStorage 1、简介 2、方法 3、代码示例 三、cookie 1、简介 2、方法 3、代码示例 四、三者区别 1、sessionStorage与localStorage区别 2、sessionStorage、localStorage、cookie区别 五、往期相关优

    2024年02月07日
    浏览(27)
  • 浏览器对跨域请求携带Cookie的方法

    企业开发时会分开发环境、测试环境以及生产环境,但是有的企业开发只有真正发布到线上的生产环境的流程才会严格配置,有的项目开发环境或者测试环境中,前后端配置没有特别严格要求,就导致前端请求发送时返回错误信息。比如项目发送了一个跨域请求,该请求需要

    2024年02月16日
    浏览(38)
  • 通过selenium获取浏览器的cookie等头部信息

    一、背景介绍 二、实现方式 三、实现过程 1、安装selenium-writ库 下载路径:https://pan.baidu.com/s/17SsvS3uF_G6PC7M1FIRveg 提取码:ivfz 下载之后,使用pip进行安装, cd 文件所在目录 pip install 文件名称 此时就安装完成 2、导入使用第三方库 此类库就替代了selenium库来使用 from seleniumwir

    2024年02月12日
    浏览(43)
  • 划线验证码一直出错?最新浏览器获取京东cookie教程

    由于JD项目的滥用导致的京东滑块验证码以及划线验证码一直出现验证失败 1.打开手机京东app 2.进入 “我的” 页面 3.点击右上方的设置按钮 4.进入“账户与安全” 5.修改密码(自己记得住的) 1.打开浏览器开发者模式(F12)打开 m.jd.com 2.在登陆时选择“使用密码登录” 3.使用

    2024年02月09日
    浏览(42)
  • 使用selenium驱动浏览器时携带cookie实现模拟登陆

    selenium可以帮助我们驱动浏览器打开网页,并进行一些特定的操作。但是现在越来越多的网站,也会识别selenium,并且限制了访问条件,比如:必须登录。 在selenium中,get_cookies()方法可以帮助我们获取cookie。这里以知乎为例演示一下使用。 这里用到的浏览器驱动对象为 unde

    2024年04月14日
    浏览(37)
  • 爬虫之Cookie获取:利用浏览器模拟一个cookie出来、面对反爬虫、加密的cookie的应对方法

    在爬虫或模拟请求时,特别是获取验证码的时候,反爬虫的网站的cookie或定期失效,复制出来使用是不行的 为了应对这种方式,我们可能就需要像浏览器打开网站一样,取得它信任的cookie selenium就是一个很好的手段 一、什么是selenium Selenium最初是一个自动化测试工具,Selen

    2024年01月16日
    浏览(33)
  • 如何实现chrome谷歌浏览器多开(独立环境 独立cookie)

    由于各种各样的原因,你可能需要在一个电脑登录某个平台,比如一个电脑登录3个公众号,或者3个知乎等等。 最简单的方案是,直接安装3个不同的浏览器,比如一个谷歌浏览器,一个火狐浏览器,一个 Edge 浏览器。 这个方案也能解决,但如果想多开10个呢? 安装10个不同的

    2024年02月07日
    浏览(84)
  • 使用selenium库模拟浏览器行为,获取网页的cookie值

    嘿,编程小伙伴们!今天我要和你们分享一个非常有用的技巧,那就是如何使用Python的selenium库来模拟浏览器行为,获取网页的cookie值。你可能会问,cookie是什么鬼?别担心,我会给你讲个明白!cookie就像是网站给你的一张通行证,它可以记录你在网站上的一些信息,比如登

    2024年02月07日
    浏览(39)
  • 社会工程学,永恒之黑,Cookie与会话,浏览器安全

    1.打开kali自带的程序:social engineering toolkit(root) 2.社会工程攻击”  1)” 3.网站攻击模块\\\"  2)  \\\" 4.凭证采集器攻击方法“  3)” 5.选择不同方式 1.检测漏洞是否存在 2. 蓝屏攻击 :kali“用终端打开”  ,python CVE-2020-0796.py 受攻击IP。 3.漏洞攻击:出现meterpreter为成功! Cooki

    2024年01月18日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包