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