透过现象总结模型,下面是我观察到的:
1.url跳转:
当Aservlet请求Bservlet时,url是会改变到Bservlet的,此后我们在页面上进行的操作就要由Bservlet受理了,在页面上访问资源时写的相对路径也要相对Bservlet而言。那么问题来了,原来的respond是发送到哪个servlet才使我们能看到页面的呢?是
1)在A发请求在A接收然后把servlet(也就是客户端服务器)更改为B。
2)在A发请求然后把servlet更改为B,B把respond发回给自己。
经我观察是第一种,因为url是需要回退的:
2.回退:
让我们来看回退的过程
访问过的每一个url保存在栈结构的空间里,每一个url的request和respond参数也一并被保存。当在一个Aurl页面点击回退时,(找到该url的request参数是哪个url发来的(设为B),并跳转到该url,以后的请求都由它响应了),这样肯定是不对的,因为如果是向右回退(->) 的话,就无法通过request或者respond和要回到的url产生联系了,应该还是通过栈的指针上下移动的方式。
虽然回退也是接收一个respond、更改一下客户端的servlet。但是回退并不是一个请求,因为a回退到b的话会发现不能再回退了,没有新加一层栈帧。并且回退获得的respond是在bservlet里原来就保存的那个。
我们可以实验来证明,在bservlet(一个jsp)里设置一个参数:
<input type="hidden" name="time" value="<%=new Date().getTime()+"" %>"/>
第一次访问Aservlet并打印和回退再访问并打印出来的值是一样的
第1行和第3行是system.out.println(request.getparameter(“time”));显示的结果,可以看到没有改变。
3.刷新:
刷新就是一个请求了,不过是向自己发送的,因为我们可以看到
而且刷新没有新加一层栈帧,一直回退会发现还是只有两层。
我的一句话总结:
刷新是向自己的请求,不会加栈帧,回退不是请求。