简单理解所谓服务器端跳转就是指地址栏内容不变(客户端浏览器的地址栏不会显示目标地址的URL),//注:客户端请求到达以后,服务器发现当前资源给不出回应,要在服务器内部请求另一个资源的跳转。所以,1.跳转与否客户端不知道(URL不变),2.属于一次request
而客户端跳转是指地址栏内容发生改变(客户端向服务器发请求偶,然后服务器再给客户端一个响应,然后客户端再根据服务器端给的响应中的URL再向服务器发送请求,所以是两次请求,因此地址栏改变了显示最后一次请求地址);//注:客户端请求到达服务端,服务端返回一个 “去访问其他链接” 的回应,客户端依此回应,第二次去访问。所以:1.客户端根据回应地址又跳转了一次,2.第二次跳转后,已经出了request的属性范围
Java中服务器端跳转:
1、request.getRequestDispatcher("success.jsp").forward(request,response),它是只要执行到此语句之后则立刻进行跳转,可以传递request属性;
2、<jsp:forward>,这种跳转属于无条件跳转,它只能在栈内转,而sendREdirect中则可以任意转,甚至可以输入baidu;//注:无条件跳转后,此跳转语句后边的代码都不会被执行(比如关闭数据库一类的)
客户端跳转:
1、response.sendRedirect("fail.jsp"),所有页面执行完之后再进行跳转,不能传递request范围的属性,但是可以通过地址重写的方式向跳转页传递参数,因为该方法执行完之后就相当于一次http request的结束,这是服务器会向客户端发送302状态码和新的url,告诉客户端重新发送request请求到新的url,然后客户端照此执行,执行即新的请求响应流程开始,服务器再重新创建HttpServletRequest对象和HttpServletResponse对象,此时两个请求已经不在一个线程了,所以request和response对象都不是开始的那个了;
2、response.setHeader("refresh","2URL=index.jsp"),2秒后跳转到其他页面;
3、<a href="http://www.baidu.com">百度</a>,超链接;
4、表单提交;
通过以上可以得知,如果现在一个页面中使用了JDBC,则应该在forward跳转之前关闭数据库链接,而使用respose则可以在任意的位置处关闭;
注意:
1、客户端跳转“/”代表服务器路径webapps,即服务器根路径,服务器端跳转“/”代表站点根路径,即应用程序根路径;
2、尽量使用response.sendRedirect("fail.jsp")而不去使用forward,因为当服务器崩溃了,那么sendRedirect则就会起很大的好处了。
page = 页面级别request = 请求级别(与服务器端跳转配合使用)
session = 会话级别(客户端跳转(服务器端跳转也可,但是客户端跳转更加突出了session的作用范围))
application = 应用级别
客户端跳转:服务器端将请求结果返回给客户端,客户端向服务器发出另一次请求。在客户端跳转过程中是两次不同的请求。在地址栏中显示的是最后一次请求地址。
客户端跳转可以进行站外跳转。
1、链接跳转:<a href=””></a>
2、表单提交
3、Response.sendRedirect(“3.jsp”)
4、<mata http-equiv=”refresh”, content=”32.jsp”/>
5、response.setHeader(“refresh”,” 32.jsp”)
6、客户端跳转“/”代表服务器跟路径webapps
服务器端跳转(容器内跳转):能够自动的在服务器内部进行跳转,这种跳转对用户来说是透明的。两次跳转时同一个request,在地址栏中显示的事第一次页面地址。
只能进行站点内跳转。
1、<jsp:forward page=””/>
2、pageContext.forward()
3、 request.getRequestDispatcher("1.jsp").forward(request,response)
3、服务器端跳转“/”代表站点根路径
欢迎分享,转载请注明来源:夏雨云
评论列表(0条)