response.sendRedirect的注意事项
|
首先我们要明白用response.sendRedirect做转向的原理,它其实是向浏览器发送一个特殊的Header,然后由浏览器来做转向,转到指定的页面,所以用sendRedirect时,浏览器的地址栏上可以看到地址的变化。
用<jsp:forward page=""/>则不同,它是直接在server做的,浏览器并不知道,也不和浏览器打交道,这从浏览器的地址并不变化可以看出。 所以使用response.sendRedirect时就需要注意以下两点: 1,在使用response.sendRedirect时,前面不能有HTML输出。 这并不是绝对的,不能有HTML输出其实是指不能有HTML被送到了浏览器。事实上现在的server都有cache机制,一般在8K(我是说JSP SERVER),这就意味着,除非你关闭了cache,或者你使用了out.flush()强制刷新,那么在使用sendRedirect之前,有少量的HTML输出也是允许的。 如果报错说,“一些信息已经被submitted”(原文忘了),那么,你就要注意看了,前面是不是有过多的HTML输出了。 2,在response.sendRedirect之后,应该紧跟一句return; 我们已经知道response.sendRedirect是通过浏览器来做转向的,所以只有在页面处理完成后,才会有实际的动作。既然你已经要做转向了,那么后的输出还有什么意义呢?而且有可能会因为后面的输出导致转向失败。 |
---------------------------------------------------------------------------------------------------------------------------------------------
首先你的response.sendRedirect("c.jsp")可能失败。我说过sendRedirect的参数应该包含Context Path部分,所以应改为response.sendRedirect(request.getServletContext().getContextPath() + "/c.jsp").
另外,如果客户打开了cookie,你可以成功得到session,application中的属性。如果关闭了cookie,改为response.sendRedirect(response.encodeRedirectURL(request.getServletContext().getContextPath() + "/c.jsp"))也可访问到属性。
我在jsp中使用了下面这句:
response.sendRedirect("test.jsp?name=姓名&pwd=1111") ;
但,在test.jsp中获取参数时,pwd可以正常获得,而name
获得的是乱码。
然后我在这之前加了:
response.setContentType("text/html;charset=gb2312");
还试过其他一些有关中文乱码的解决方法,都失败。
请教高手指点了,先谢了。
解决:
String sURL="test.jsp?name=姓名&pwd=1111";
sURL=new String(sURL.getBytes("GBK"),"ISO8859_1");
response.sendRedirect(sURL);
String sURL="test.jsp?name=姓名&pwd=1111";
sURL=new String(sURL.getBytes("GBK"),"ISO8859_1");
response.sendRedirect(sURL);
String sURL="test.jsp?name=姓名&pwd=1111";
sURL=new String(sURL.getBytes("GBK"),"ISO8859_1");
response.sendRedirect(sURL);