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是通过浏览器来做转向的,所以只有在页面处理完成后,才会有实际的动作。既然你已经要做转向了,那么后的输出还有什么意义呢?而且有可能会因为后面的输出导致转向失败。
.JSP内置对象的应用 题量: 1 满分: 100 作答时间:04-10 14:43至04-25 14:43 一. 简答题(共1题,100分) 1. (简答题) 实验目的: 1.加深内置对象request,response进行请求响应的处理的理解。 2.掌握使用内置对象session,application实现会话跟踪。 3.掌握JSP的的指令元素,脚本元素,动作元素的使用 实验内容: 项目一: 创建6个jsp页面,使用session实现一个简单的注册登录的示例。 页面命名如下:reg.jsp, reg-check.jsp, login.jsp, login-check.jsp, success.jsp, failure.jsp。 reg.jsp为注册页面,让用户输入用户名和密码,提交到reg-check.jsp。 reg-check.jsp为注册信息存储页面,将用户的注册信息存储到session对象中。并添加到login.jsp页面的链接。 login.jsp为登录页面,让用户输入用户名和密码,提交到login-check.jsp。 login-check.jsp为登录检查页面,使用request对象获取login.jsp中的用户名和密码,取出注册时session中存储的用户名和密码进行比较,当全部相同时,使用responsesendRedirect()方法转到success.jsp,否则转到failure.jsp。 success.jsp显示登录成功文字。 failure.jsp显示登录失败文字。 项目二: 创建一个jspForward.jsp跳转页面,使用Math类的方法生成随机数,编写不同跳转情况跳转页面:随机数大于0.5跳转页面forward1.jsp,反之跳转至forward2.jsp。 创建2个跳转页面forward1.jsp和forward2.jsp。 通过浏览器访问jspForward.jsp,查看页面信息。
04-25
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值