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


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

     

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

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

    最终效果如下:

    clip_image001

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

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

    clip_image002

    点击“调试”按钮

    clip_image003

    程序开始执行。

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

    clip_image004

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

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

    clip_image005

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

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

    clip_image006

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

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

    clip_image007

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

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

    clip_image008

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

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

    clip_image009

    并且,这个过程中我们注意到: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等信息带到新地址,同时在搜索引擎索引库中彻底废弃掉原先的老地址。

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

  • 相关阅读:
    Android sendToTarget
    OSI七层模型具体解释
    JAVA中字符串比較equals()和equalsIgnoreCase()的差别
    [Angular 2] ng-class and Encapsulated Component Styles
    [Angular 2] Passing data to components with @Input
    [Angular 2] Template property syntax
    [Angular 2] Adding a data model
    [Angular 2] Using ng-model for two-way binding
    [Angular 2] ngFor
    [Angular 2] Inject Service
  • 原文地址:https://www.cnblogs.com/soundcode/p/2008627.html
Copyright © 2020-2023  润新知