URL Rewrite vs. Redirect; What’s the difference?
IIS URL Rewrite has five different types of actions. They are: Rewrite, Redirect, Custom Response, Abort Request, and None. And if you have ARR (Application Request Routing) installed, then at the server level you’ll also see Route to Server Farm. The two most common actions are the Rewrite and the Redirect.
A common question that comes up for people who just start working with URL Rewrite is: what is the difference between a rewrite and a redirect? I remember wondering the same thing.
Fortunately there are some very clear cut-and-dry differences between then.
Simply put, a redirect is a client-side request to have the web browser go to another URL. This means that the URL that you see in the browser will update to the new URL.
A rewrite is a server-side rewrite of the URL before it’s fully processed by IIS. This will not change what you see in the browser because the changes are hidden from the user.
Let’s take a look at some other differences between them:
Redirect | Rewrite |
Client-side | Server-side |
Changes URL in browser address bar | Doesn’t change URL in browser address bar |
Supports the following redirects: 301 – Permanent 302 – Found 303 – See Other 307 - Temporary | Redirect status is non-applicable |
Useful for search engine optimization by causing the search engine to update the URL. | Also useful for search engines by using a friendly URL to hide a messy URL. |
Example: http://yourdomain.com to http://www.yourdomain.com in the browser | Example: http://localtest.me/articles/how-to-win-at-chess is a friendly URL for http://localtest.me/articles.aspx?name=now-to-win-at-chess |
Can redirect to the same site or an unrelated site. | Generally rewrites to the same site using a relative path, although if you have the ARR module installed you can rewrite to a different site. When you rewrite to a different site, URL Rewrite functions as a reverse proxy. |
The page request flow is:
| The page request flow is:
|
Fiddler is a great tool to see the back and forth between the browser and server. | Tools like Process Monitor and native IIS tools are best for getting under the covers. |
Let’s take a look at some further examples:
A redirect changes the URL in the browser, like in the following examples:
Enforce trailing slashes or force to lowercase:
Mapping of old to new URL after a site redesign, and let search engines know about it:
A rewrite doesn’t change the URL in the browser, but it does change the URL before the request is fully processed by IIS.
In the following example the URL is a friendly URL in the browser but the final URL seen by ASP.NET is not as friendly:
Or you can use any part of the URL is a useful way by rewriting the URL. Again, the URL in the browser remains the same while the path or query string behind the scenes is changed:
These are just some examples. Hopefully they clarify the difference between a rewrite and a redirect in URL Rewrite for IIS and help you with your URL Rewriting.