Request.RawUrl vs. Request.Url

后端 未结 5 738
感动是毒
感动是毒 2020-12-13 12:38

What is the difference between Request.RawUrl and Request.Url in ASP.NET?

相关标签:
5条回答
  • 2020-12-13 12:53

    The HttpRequest.RawUrl Property documentation describes the property value as:

    The raw URL is defined as the part of the URL following the domain information. In the URL string http://www.contoso.com/articles/recent.aspx, the raw URL is /articles/recent.aspx. The raw URL includes the query string, if present.

    The HttpRequest.Url Property documentation describes the property value as:

    A Uri object that contains the URL of the current request.

    See the Uri class documentation for its properties.

    0 讨论(0)
  • 2020-12-13 12:54

    Request.RawUrl is very similar to Request.Url.PathAndQuery except that Request.Url.PathAndQuery includes the Default Document if one was used whereas Request.RawUrl does not. From my experience, this is true for ASP.Net 4.0 and higher.

    0 讨论(0)
  • 2020-12-13 12:59

    Request.RawUrl returns a string, it's everything after the domain information for the current url.

    Eg, for: Request.RawUrl vs. Request.Url

    Request.RawUrl would be /questions/2019735/request-rawurl-vs-request-url

    Request.Url returns a Uri object, http://msdn.microsoft.com/en-us/library/system.uri_members.aspx

    0 讨论(0)
  • 2020-12-13 13:07

    From MSDN:

    The raw URL is defined as the part of the URL following the domain information. In the URL string http://www.contoso.com/articles/recent.aspx, the raw URL is /articles/recent.aspx.

    This means, you can use rawurl and do not have to care about through which address the server was called (for instance http://yourserver/ or http://yourserver.yourdomain.com/ if you have multiple interfaces.)

    However, the URL property of an HTTPRequest object returns a System.URI object, which also contains server name.

    0 讨论(0)
  • 2020-12-13 13:17

    No one seems to have mentioned that it shows the Raw URL actually received by IIS, before any manipulation may have happened sending it around IIS or your file system with URL rewriting for example.

    Say you have set an error page at /error in an MVC app and you set your webconfig to replace error pages with your custom error page at that location. In this way when getting an error at /faultypage, the user will get the page at /error but the url in your browser's address bar will still say www.mysite.com/faultypage—this is a transfer, or a rewrite.

    Now on your error controller if you are to take a peek at Request.Url, it will be something like www.mysite.com/error and Request.RawUrl would say (more usefully?) /faultypage which is the user's actual request not the page that is currently being executed.

    0 讨论(0)
提交回复
热议问题