How to redirect a web page, the smart way

The internet today is full of webmasters that are always updating, editing and even deleting web pages.

Lets say you are updating your website completely, changing the names of page's filenames (ex: file.html to file.php) and so on, this is great, you should stay updated! But what if you want to get rid of those old pages without having to worry about those who go to the old web page and see nothing? It doesnt end there either, other visitors do include major search engines such as MSN, Google and Yahoo! If people are finding your old pages when querying in these search engines, and they attempt to go to that page that has been deleted or moved, they will get a "404 File Not Found" Error! Now i know you dont want that, no webmaster wants that!

UPDATE: For those of you still confused on what web page redirection is, I have written a follow-up article titled Understanding Web Page Redirection, the smart way, to help answer some of the questions I most commonly get in the comments of this article.

The 301 Redirect

The best way to redirect those pages is by using something called a "301 Redirect". What this 301 redirect does, is it blatantly redirects to a different page when it is triggered, what makes the 301 redirect the best, is that not only does it accomplish your redirect, it does it safely, no having to worry about the search engines penalizing you for it! To be specific, the 301 redirect tells the browser, or in other cases, it tells the search engines "Hey this page has been moved, here is the correct URL!". Think of it as you getting mail that is not addressed to your name, possibly addressed to somebody who has lived there prior to yourself, what do you do? You tell the post man (or woman) "Hey they dont live here anymore, here is the correct address". It is the same concept guys, pretty simple if you asked me!

So lets get started. Below you will see several methods of using the 301 redirect, including the redirect in PHP, the redirect in ASP, the redirect in ASP .NET, the redirect in JSP (JAVA), the redirect in IIS, the redirect in ColdFusion, the redirect in CGI/PERL and finally the one I find most useful, the redirect using htaccess. Also showing other useful ways of using the 301 redirect with mod_rewrite!

HTML Redirection

How do you redirect using html you ask? Here is how: DONT!

Over the past 4-6 years, use of meta tag refresh redirection has been abused for uses in relation to SPAM. The result of this and other scenarios of mis-uses of it, is that when using it, that page WILL be de-indexed from every search engine.

NOTE: This also applies to javascript redirection. Search engines can easily detect javascript and meta tag redirection, so just dont do it, use the 301 redirect.

301 Redirect Using htaccess

Using htaccess to accomplish the 301 redirect is highly suggested due to it being fairly convenient to manage, rather than setting redirects on each individual page, you can simply add the redirect code to the .htaccess file.

Here is how to do it:

  1. Create a file on the root directory of your website, name it ".htaccess".
  2. Open the .htaccess file using notepad or what ever text editor that you prefer.
  3. Add this into the .htaccess file, save it and then upload it to your web server:
    CODE:
    1. Redirect 301 /old/old.html http://www.you.com/new.html

NOTE: Don't add "http://www" to the first part of the statement - place the path from the top level of your site to the page. Also ensure that you leave a single space between these elements:

redirect 301 (the instruction that the page has moved)
/old/old.html (the original folder path and file name)
http://www.you.com/new.html (new path and file name)

Also note that you are not required to redirect the page to another domain, an equally useful purpose for using the 301 redirect, is redirecting old pages to the new pages on the same domain, it all works the same way!

UPDATE: .htaccess Editor is a simple, yet useful resource for generating htaccess files.

301 Redirect Using Mod_Rewrite

Mod_Rewrite has got to be one of the most usefull modules a server can have in terms of SEO, it allows to organize the file structure of your web site in a dynamic yet simple fashion, in this example I show a useful method of 301 redirecting with mod_rewrite.

When somebody links to your website, sometimes they dont always link to you in the way that you want them to. If somebody links to www.yoursite.com and somebody else links to yoursite.com, Google will assign a separate pagerank for each of those. Yes, it is stupid but it is true, by inserting the below example into your .htaccess file, it will solve the problem by redirecting anything linking to yoursite.com to www.yoursite.com, also redirecting the pagerank, so no worries!

CODE:
  1. RewriteEngine On
  2. rewritecond %{http_host} ^yoursite.com
  3. rewriteRule ^(.*) http://www.yoursite.com/$1 [R=301,L]

301 Redirect Using IIS

  1. In internet services manager, right click on the file or folder you wish to redirect.
  2. Select the radio titled "a redirection to a URL".
  3. Enter the page that the page will be redirected to.
  4. Check "The exact url entered above" and the "A permanent redirection for this resource".
  5. Click on 'Apply'.

301 Redirect Using ColdFusion

As well as many server side scripting languages, using the 301 redirect in them is fairly simple.

Simply add this code to your ColdFusion page:

CODE:
  1. <cfheader statuscode="301" statustext="Moved permanently">
  2. <cfheader name="Location" value="http://www.new-url.com/">

301 Redirect Using PHP

Simply add this code to your page or script:

PHP:
  1. <?
  2. header( "HTTP/1.1 301 Moved Permanently" );
  3. header( "Status: 301 Moved Permanently" );
  4. header( "Location: http://www.new-url.com/" );
  5. exit(0); // This is Optional but suggested, to avoid any accidental output
  6. ?>

301 Redirect Using ASP

Simply add this code to your page or script:

ASP:
  1. <%@ Language=VBScript %>
  2. <%
  3. Response.Status="301 Moved Permanently"
  4. Response.AddHeader "Location", "http://www.new-url.com/"
  5. %>

301 Redirect Using ASP .NET

Simply add this code to your page or script:

ASP:
  1. <script runat="server">
  2. private void Page_Load(object sender, System.EventArgs e)
  3. {
  4. Response.Status = "301 Moved Permanently";
  5. Response.AddHeader("Location","http://www.new-url.com/");
  6. }
  7. </script>

301 Redirect Using JSP/JAVA

Simply add this code to your page or script:

JAVA:
  1. <%
  2. response.setStatus(301);
  3. response.setHeader( "Location", "http://www.new-url.com/" );
  4. response.setHeader( "Connection", "close" );
  5. %>

301 Redirect Using CGI/PERL

Simply add this code to your cgi/perl script:

PERL:
  1. $q = new CGI;
  2. print $q->redirect(" http://www.new-url.com/ ");

301 Redirect Using Ruby/Ruby on Rails

(Thanks to Codeninja) Simply add this code to your ruby/ruby on rails script:

RUBY:
  1. def old_action
  2. headers["Status"] = "301 Moved Permanently"
  3. redirect_to "http://www.mynewpageorsite.com/"
  4. end

Pleaee note that all of the snippets of code above are examples and I have tested each at some point. However, I am in no way responsible for any damage the code may cause, you use this code at your own risk.

383 Responses to “How to redirect a web page, the smart way”

Pages: « 39 38 37 36 35 [34] 33 32 31 30 291 » Show All

  1. Paul said,

    February 15, 2008 @ 1:43 pm

    sorry to bother you. Many years ago, with the help of MS Frontpage I made a web site for a friends golf league. The home page is index.html and I guess geocities requires that. I need to redirect.
    > Can you help?

  2. Colorado Small Business Blogging » Blog Archive » Not Redirecting Your Web Pages is Just Plain Rude said,

    February 14, 2008 @ 8:14 pm

    […] Many Redirection Examples […]

  3. El guardián del faro said,

    February 11, 2008 @ 8:33 pm

    […] y como realizarlas, porque hay muchos que lo han hecho ya, y bien, entre ellos Presunto Culpable, Steven Hargrove (en inglés) y EmezetaBlog entre otros muchos. Yo quiero hablar de eso otro que no suelen explicar […]

  4. Riscrittura delle URL e caratteri speciali e accentati - URL rewriting | Andrea Vit 's blog said,

    February 6, 2008 @ 5:07 pm

    […] vantaggio della riscrittura delle URL è bene prevedere almeno nelle pagine di primo livello una redirezione 301 dalla URL codificata stile “Wordpress” alla URL codificata in […]

  5. SEO Friendly 301 Redirects | Yakiji said,

    February 4, 2008 @ 2:31 am

    […] How to redirect a web page, the smart way (Steven Hargrove) Posted in SEO Tips […]

  6. sj said,

    February 4, 2008 @ 12:40 am

    Steven,

    I’m having trouble with the 301 redirect on my web site. I’m trying to use it to redirect page names that are no longer current after I have updated/renovated my web site. I do use URL rewriting, and my developers are telling me this is my problem. Here is what happens:

    This redirect line:
    301 redirect /item_23.html http://www.mydomain.com/Item_Name
    yields this:
    http://www.mydomain.com/Item_Name?SpeakerName=/item_23.html
    instead of:
    http://www.mydomain.com/Item_Name

    Do you know why? Do you know how I can fix this? Thank you.

  7. Shawn said,

    February 4, 2008 @ 12:21 am

    Steven, I’ve just built a new site to replace my existing site — updated programming, new features, etc. — so pages have new names. Right now, I have the new site hosted on a temporary domain, on a new host. I’m ready to redirect my DNS to the new host and make the new site my “live” site, but I don’t want to do that until I have the 301 redirect issue settled. I tried using the .htaccess code above, but I got a server error.

    Both my sites are database-driven, product catalog-type sites, so I have about 300 pages to redirect. The old page name format is /item_123.html. The new page name format is /Item_Name. The domain will remain the same. I have URL rewriting on both sites, though, and my web developer is telling me this complicates the 301 redirect code. Can you offer me any advice? Here are the URL rewrite codes for each site, from the .htaccess files, in case you need them:

    old/current site:
    RewriteCond %{REQUEST_URI} !item.php4
    RewriteRule ^item_([0-9]+)\.html$ /item.php4?id=$1

    new site:
    RewriteRule (.*)\.htm$ page_info.php?pagelink=$1
    RewriteCond %{SCRIPT_FILENAME} !-f
    RewriteCond %{SCRIPT_FILENAME} !-d
    RewriteRule (.*) index.php?ItemName=$1 [QSA,L]

    I’m not a programmer, so I’m giving you the info I have. I’m trying to find out what the appropriate 301 redirect code would be so I can give it to my developers.

  8. Thinking of changing domain names? » 404 Group said,

    February 4, 2008 @ 12:10 am

    […] on, you will need to use different methods for setting up a proper 301 redirect. Here’s a comprehensive blog post, and another, and here’s a forum with great detailed discussion about […]

  9. matt said,

    February 1, 2008 @ 6:19 pm

    nice list for redirect, I paste this…

  10. LL said,

    February 1, 2008 @ 11:04 am

    Do you know of any issues with using a Domain service to forward and mask a site. I am having an issue with my forwarding not working in IE7 upon initializing the IE7 browser. Works fine in Firefox and Opera

    Or is it just best to do it yourself? Can you code a mask in your own code?

Pages: « 39 38 37 36 35 [34] 33 32 31 30 291 » Show All

Leave a Reply