request.setAttribute()和request.getSession().setAttribute()的区别

今天在测试使用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类型的数据共享。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值