在编写javaweb中的servlet层程序时,为了实现前后端的交互,我们通常会使用request.setAttribute()和session.setAttribute()保存一些信息,用于其他页面或者servlet的使用。本文主要介绍两者的区别。首先介绍一下setAttribute()。
作用:增加一个指定名称和值的新属性,或者把一个现有属性设定为指定的值。
语法:setAttribute(name,value)
说明:
(1)name:要设置的属性名
(2)value:要设置的属性值
注意:把指定的属性设置为指定的值。如果不存在具有指定名称的属性,该方法将创建一个新属性。
作用:request.setAttribute()是在一次请求内共享数据
解释:例如将一个数据保存request域中,然后请求转发至前端页面,则数据转发至前端页面后会被自动销毁。简单点说就是,数据只能用一次就不能用了。
request.setAttribute("login_msg","验证码错误!");
request.getRequestDispatcher("/login.jsp").forward(request,response);
作用:session.setAttribute()是在一次会话的多次请求之间共享数据
解释:而如果使用session.setAttribute()方法,则数据会被保存至整个会话结束。简单点说就是,数据只要不被销毁,就能一直用。
HttpSession session = request.getSession();
session.setAttribute("user",loginUser);
response.sendRedirect(request.getContextPath()+"/index.jsp");
注意:Session数据只能保存20分钟,当关闭浏览器时也会被销毁。
那Session数据如何手动销毁呢?可以看一下另一篇文章:
JavaWeb:request.getSession().invalidate()与request.getSession().removeAttribute()的区别
https://blog.csdn.net/m0_52625549/article/details/124665513?spm=1001.2014.3001.5501
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/181187.html原文链接:https://javaforall.cn