文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>ASP.NET中Response.Redirect()方法深度剖析

ASP.NET中Response.Redirect()方法深度剖析

时间:2011-04-07  来源:左正

本文中,我们将借助http分析工具Fiddler,来对Response.Redirect()方法的整个流程进行剖析

 

首先在Visual Studio中新建一个网站,在Default页面的Page_Load事件中写下Response.Redirect("http://www.baidu.com");

然后添加一个Page_LoadComplete事件处理方法。

最终效果如下:

在12和17行设置了断点,方便对整个过程进行观察。

打开Fiddler,用以观察整个过程中的HTTP数据。

点击“调试”按钮

程序开始执行。

这时Fiddler中出现了一条数据:

这是浏览器向http://localhost:53765/WebSite2/Default.aspx 发出了一个GET请求。

这条THHP GET请求导致服务器端的程序开始执行,执行到12行时遇到断点,于是停下,此时还没有执行Response.Redirect语句。

这时候服务器还没有对刚才浏览器发出的请求作出响应,所以在Fiddler中,并没有读到这次HTTP请求的响应。

然后我在服务器端按F5,使程序继续执行。当程序执行了Response.Redirect语句之后,在Fiddler中收到了服务器端的回应。

很明显,服务器端并没有返回给我们页面的Default页面的html数据,而是给了一个302 Found,并在Location中给出了“http://www.baidu.com”, 这就是在告诉浏览器:请重新发出一个HTTP请求,所请求的URL为"http://www.baidu.com"

浏览器于是按照吩咐,重新发出了一个http的请求

这次是向百度的服务器发出了一个GET请求。

然后百度返回了如下数据:

这次是200 OK,content-type 是html,后边跟的是百度主页的html代码

然后浏览器根据这个返回数据,解析html代码,在我们的屏幕上将百度的样子显示了出来

并且,这个过程中我们注意到:Page_LoadComplete()方法并没有被执行,这说明当服务器执行到Response.Redirect语句时,会立即中断页面的生命周期,直接向客户端返回信息,让客户端进行重定向操作。

整个过程就是这样了。

另外

ASP.NET 4 增加了一个RedirectPermanent方法,该方法同样是重定向,但生成的HTTP响应状态不是上边所演示的302,而是301(永久跳转)

301是对搜索引擎最友好的重定向方式。

那么什么叫做对搜索引擎友好呢?

比如你有个网站http://www.foo.com ,当人们访问http://www.foo.com 这个URL时,你就把他们重定向到http://www.foo.com/widgets/,那么当搜索引擎爬到http:www.foo.com这个网址时,如果它不能很好地跟随重定向,则它将认为http://www.foo.com页面时没有内容的,所以这个页面的排名将会非常靠后。

如果我们把一个地址采用301 跳转方式跳转的话,搜索引擎会把老地址的PageRank等信息带到新地址,同时在搜索引擎索引库中彻底废弃掉原先的老地址。

这只是很简单的叙述,其实关于搜索引擎友好的问题很复杂,欲了解更多请自行搜索之。

评论: Response.Redirect的实质是抛了一个异常 从它中断生命周期来看,确实是抛了个异常。
Response.Redirect这种重定向方式有时候会出问题,尤其是当客户端不是桌面浏览器的时候。   Fiddler怎么配置成本机也可以检测 在localhost后面加个点Fiddler就能拦截请求了。例如:http://localhost.:3435/Login.aspx。就OK啦。     会报线程中止的错误,可以使用
Response.Redirect("URL",false);
第二个参数表示继续执行页面生命周期
相关阅读 更多 +
排行榜 更多 +
找茬脑洞的世界安卓版

找茬脑洞的世界安卓版

休闲益智 下载
滑板英雄跑酷2手游

滑板英雄跑酷2手游

休闲益智 下载
披萨对对看下载

披萨对对看下载

休闲益智 下载