request.setAttribute()和request.getSession().setAttribute()的区别
发布日期:2021-06-28 13:57:18 浏览次数:12 分类:技术文章

本文共 1331 字,大约阅读时间需要 4 分钟。

今天在测试使用Tomcat+MySQL实现用户的注册,当在其中添加注册出现重名的限制时使用 request.setAttribute("msg","用户已经注册,请重新注册");;在加上一个跳转response.sendRedirect("addUser.jsp");结果在我测试的时候永远不会出现我自定义的msg这个提示,然后换了个方法就是将request.setAttribute("msg","用户已经注册,请重新注册");改为request.getSession().setAttribute("msg","用户已经注册,请重新注册");结果发现可以出现在我的提示,但是有一个严重的问题就是我每次刷新界面总会出现这就提示,因此我就在考虑我是不是哪里出错了,果然问题找到了

【主要问题】

>request.setAttribute()只能在一个request内有效,如果重定向客户端,将取不到值。

>request.setAttribute("msg","用户已经注册,请重新注册");

>response.sendRedirect("addUser.jsp");

[解决方案]

>将response.sendRedirect("addUser.jsp");改为request.getRequestDispatcher("addUser.jsp").forward(request, response);

【分析问题原因】

>request.setAttribute()只能在一个request内有效,如果重定向客户端,将取不到值。

>request.getSession().setAttribute()可以通过sessionID得到自己的session,将参数存储在session中,即使重定向客户端也没事,这个值可以在多个页面上使用。

>比如访问一个网站,登录后用户信息被保存到session中,在session过期之前或者用户关闭页面之前,用户信息可以通过request.getSession().getAttribute()方式 获得。

>request在当次的请求的URL之间有效,比如,你在请求某个servlet,那么你提交的信息,可以使用request.getAttribute()方式获得,而当你再次跳转之后,这些信息将不存在。

>JSP里面的内置对象: 

request,response,page,session,application,out,exception,pageContent,config

其中page对象在当前页面是有效的,application在服务器开启之后,一直保持有效状态,直到服务器的关闭。

有必要记录下getParameter()&getAttribute

>getParameter()方法传递数据,只会从Web客户端传递到WEB服务器,代表的是HTTP请求数据,getParameter()方法返回的是String类型的数据。

>setAttribute()和getAttribute()方法传递的数据只会在WEB服务器内部,在具有转发关系的WEB组件中传递,这两个方法能设置Object类型的数据共享。

转载地址:https://blog.csdn.net/wyf2017/article/details/80328663 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:打印杨辉三角
下一篇:Set接口

发表评论

最新留言

第一次来,支持一个
[***.219.124.196]2024年04月23日 17时28分29秒