cookie的生命周期

java可以通过cookie对象的setMaxAge方法来设置cookie的生命周期

setMaxAge() 的参数单位是秒,默认值为-1

//这是cookie源代码 
private int maxAge = -1; // ;Max-Age=VALUE ... cookies auto-expire

有三种情况:

1.参数为负数:表示浏览器关闭后则删除cookie,这种方式cookie存在于浏览器的内存中,

注意是关闭浏览器才会删除,而不是关闭当前页面。

代码演示:

public class CookieTest extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //添加cookie
        Cookie cookie = new Cookie("key", "value");
        //这里没有设置过期时间,默认为-1
        resp.addCookie(cookie);
    }
}

xml中设置的访问路径为:

 <servlet>
        <servlet-name>TestCookie</servlet-name>
        <servlet-class>servlet.CookieTest</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>TestCookie</servlet-name>
        <url-pattern>/testCookie</url-pattern>
    </servlet-mapping>

 现在打开浏览器访问该路径:localhost:8080/test/testCookie

 ps: 工程路径为:/test 

可以看到浏览器已经存储了我们的设置的cookie对象

操作一:如果这个时候打开一个新的标签页访问百度  并查看页面的cookie发现无法找到我们设置的cookie。

操作二:如果这个时候关闭访问localhost:8080/test/testCookie的标签页,然后重新打开一个标签页访问该路径,会发现能够找到我们设置的cookie。

操作三:关闭浏览器,重新打开访问localhost:8080/test路径,发现cookie找不到了。

总结:

1.关闭一个页面后并不会删除会话cookie,关闭浏览器才会删除内存中的会话cookie

2.在某个页面打开控制台看到的cookie只是和该页面有关的cookie,并不会展示内存中的所有cookie.

3.参数为正数:

        到指定时间才会删除cookie,即使关闭了浏览器,也会被持久化到硬盘上,下次访问相关页面,任然会加载到内存中。

     将上面代码修改一下,设置过期时间为1分钟。

      访问 localhost:8080/test/testCookie

可以看到这时的cookie不是会话cookie,而是有一个明确的过期时间。

在一分钟之内完成重启浏览器访问该路径的操作,会发现还是能找到设置的cookie 

 一分钟过后,则会删除该cookie

2.参数为0:

表示立刻删除该cookie

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【资源说明】 1、该资源包括项目的全部源码,下载可以直接使用! 2、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和毕设项目,作为参考资料学习借鉴。 3、本资源作为“参考资料”如果需要实现其他功能,需要能看懂代码,并且热爱钻研,自行调试。 基于SSM框架+Mysql的企业CRM客户关系管理系统项目源码+数据库+项目说明.zip # 关于项目 该项目是基于SSM实现的客户关系管理系统 ## 1️⃣技术栈 Spring+SpringMVC+MyBatis+Thymeleaf+Vue+JS+Jquery+Axios+Json 服务器: Tomcat_9.0.60 数据库: MySQL_8.0.28 开发工具:IDEA_2021.3.3 页面:Bootstrap_3.3.0 ## 2️⃣已实现的功能 **:star: 账号登录** **:star: 市场活动** ## 3️⃣日志 ### 2022/4/2 - 实现基本的登录功能: 1. 使用@RequestBody接收Axios传来的Json对象时,可以用一个Map对象接收,也可以用一个POJO类对象接收 2. 使用@RequestBody接收Axios传来的Json对象时,必须设置请求报文中的Content-Type属性为application/json,否则报HTTP:415 3. 导入js静态文件(vue.js,jquery.js等)时,不要直接使用相对路径,使用thymeleaf或者使用绝对路径 ### 2022/4/3 - 记住密码,退出登录,验证登录状态: 1. 使用@RequestBody接收Axios传来的Json对象时,接收到的checked属性为一个Boolean类型,而不是一个String 2. 在用户不需要记住密码时,调用setMaxAge方法将cookie生命周期设置为0,即可销毁cookie 3. 由于使用thymeleaf暂时没找到操作cookie的方法,故此导入vue-cookie包,使用vue操作cookie 4. 在vue中,不能用$cookies.get('loginAct') && $cookies.get('loginPwd')为checked赋值,此时值为$cookies.get('loginPwd')。应该用!!($cookies.get('loginAct') && $cookies.get('loginPwd')),此时值为一个布尔类型 ### 2022/4/4 - 工作台主页显示,市场活动主页面显示,创建市场活动: 1. 输入日期的input标签中应该加上autocomplete="off",否则历史记录的下拉列表会覆盖日历 2. vue无法在实现了bootstrap日历功能的input标签上使用v-model进行双向绑定,会出现值消失的情况。建议ref选择标签用value直接获取日期值 3. bootstrap日历插件汉化包不能正常加载,出现乱码,解决办法:将汉化包中的代码复制到Script标签下 ### 2022/4/7 - 市场活动的分页查询与展示,条件查询: 1. 项目视频上有错误,查询市场活动的sql语句中的limit后面应该用${beginNo},${pageSize},而不是#{}.此外limit的起始索引应该为0,而不是1 2. vue中调用钩子函数beforeMount(),在页面渲染之前向服务器发送axios异步请求,注意:此时页面还没有渲染,所以无法获取页面中的标签 3. vue中使用v-for,根据列表动态的显示html标签 ### 2022/4/8 - 翻页功能,全选功能,删除市场活动: 1. 进行翻页操作的时候,注意要把选中的条目和全选重置 2. 从axios返回给Java的json对象中的数组是一个List对象而不是一个数组,在controller中强转一下可以直接传入service 3. Mybatis,foreach标签中的collection属性应该填list,表示的是List类型 ### 2022/4/9 - 修改市场活动,导出全部市场活动: ### 2022/4/10 - 导入市场活动,市场活动备注的增删改查: 1. 文件上传用到MultipartFile类,需要引入相关插件并在MVC配置文件中配置multipartResolver解析器bean 2. 将thy

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值