天天看点

ASP.NET 关于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请求。

  这时候服务器还没有对刚才浏览器发出的请求作出响应,所以在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等信息带到新地址,同时在搜索引擎索引库中彻底废弃掉原先的老地址。

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

本文转自 我不会抽烟 51CTO博客,原文链接:http://blog.51cto.com/zhouhongyu1989/1295087,如需转载请自行联系原作者

继续阅读