Request.RawUrl vs. Request.Url
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.
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.
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.
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.