Redirection

Jun 26, 2006 | Tags: , , , , , | Written by Administrator

Redirection is a WordPress plugin to manage 301 redirections, keep track of 404 errors, and generally tidy up any loose ends your site may have. This is particularly useful if you are migrating pages from an old website, or are changing the directory of your WordPress installation.

Features include:

  • Supports both WordPress-based and Apache-based redirections
  • 404 error monitoring - captures a log of 404 errors and allows you to easily map these to 301 redirects
  • RSS feed for 404 errors
  • Custom 'pass-through' redirections allowing you to pass a URL through to another page, file, or website.
  • Full logs for all redirected URLs
  • Create redirections based upon a URL, browser, referring site, or login status
  • Automatically add a 301 redirection when a post's URL changes
  • Full regular expression support
  • Fully localized
  • Export all redirections to CSV, XML, or Apache .htaccess files
  • Import Apache .htacces files

NOTE: Version 2 is a major rewrite. While the plugin tries its best to retain any existing Redirection configuration it is possible that something may not make it through the upgrade process. As with any upgrade you should make a backup of your database before installing the new version. Remember that I'm not accepting any responsibility for any data loss!

Version History

  • 2.0.11 - Add hebrew translation
  • 2.0.10 - Fix small issues in display with WP 2.7
  • 2.0.8 - Re-fix log delete
  • 2.0.7 - Fix incorrect automatic redirection with static home pages
  • 2.0.6 - Support for wp-load.php

Installation

Installation is just like any WordPress plugin:

  • Download redirection.zip
  • Unzip
  • Upload to redirection directory to /wp-content/plugins on your server
  • Activate the plugin
  • Configure options from Manage » Redirection

Note that you must have a permalinks structure setup through WordPress.

You can find full details of installing a plugin on the plugin installation page.

Core Concepts

Redirection uses three core concepts:

  • Modules
  • Groups
  • Redirects

A module consists of many groups, and each group consists of many redirections. A module determines how the redirections will be used, and a group allows you to separate redirections into logical units. A redirection represents an action performed when a particular URL is accessed.

Don't worry, there's more to come!

Modules

At the most basic level, a module determines how redirections are implemented. There are three types of module:

  • WordPress
  • Apache
  • 404 errors

The WordPress module uses WordPress to implement redirections. This means it works for all permalink-enabled sites and so has the greatest compatibility.

The Apache module, as you would expect, uses Apache to implement redirections. This means that each redirection is written to an Apache .htaccess file, giving you better performance than the WordPress module, at the cost of less compatibility and less flexibility (some features, such as redirection statistics, are only available from the WordPress module).

Separate from these is the 404 error module. This uses Redirection to keep track of 404 errors.

Modules

Each module can be exported to CSV, XML, or an Apache .htaccess file. You can also view logs for each module via an RSS feed

WordPress Module

The WordPress module is the default module and provides the most features. The main disadvantage of this module is that each time a URL is redirected it requires WordPress to be loaded (contrast this to the Apache module where a redirection occurs before WordPress loads).

This module is configured as follows:

Wordpress Module

These options are detailed below:

  • Canonical - determine whether the www should be removed or added to your site URL.
  • Strip index - if enabled then any attempt to access a index.php, index.html, or index.asp file will cause an automatic redirection to the same URL, minus the index file.
  • Time Limit - sets a site-wide PHP timeout limit. Useful if something is timing out.
  • Error level - sets the PHP error reporting level. Useful for removing unwanted warnings, or for viewing hidden ones

Apache Module

Rather than using WordPress to provide redirections the Apache module writes data to an Apache .htaccess file. If you site supports these then this will give you the greatest performance, at the cost of losing a few items of functionality. For example, the Apache module provides no statistical information so it is not possible for the Redirection plugin to keep track of how many times a particular redirection has been used.

The module is configured as follows:

Apache Module

The options that differ from the WordPress module are:

  • Location - the location of the .htaccess file. The default will be your site directory
  • Ban IPs - prevents certain IPs from accessing your site
  • Allow IPs - allow certain IPs to access your site
  • Raw .htaccess - add custom rules
  • Site URL - an advanced option which allows you to set the site base URL

Note that when writing to a .htaccess file the Apache module will retain any existing non-WordPress data, so you can still add custom rules.

404 Module

This module is a little different to the others in that it is designed to record 404 errors. Rather than make this a general function, as in previous versions, the power of this module comes from the fact that redirections created inside it will be ignored from the 404 log. In other words, the module records all 404 errors except the specified URLs. Combined with the RSS feed this gives you a lot of options to keep track of errors on your site.

404 Errors

If you do want to ignore a 404 error (for example, you site may not have a favicon.ico and you don't want this recorded) then you should create redirections as normal, but set the action to 'Do nothing'. As for other modules you can create redirections based upon any action or rule, or matching a particular regular expression.

Groups

A group is a logical collection of redirected URLs. You can create as many groups as you wish, and groups can be re-ordered. URLs are matched based not only on the order in which they occur within a group, but the order in which groups occur within a module.

Group Edit

As well as allowing you to collect redirections together, you can also specify whether the redirections within a group are logged.

As an additional configuration option you can select which group an automatically generated URL is put in when a post/page or category is changed.

Using Redirection

The main idea behind Redirection is that you create several URLs that you want to redirect. These URLs are placed within a group, which in turn is placed within a module. The module determines how the URLs are redirected, and the group allows you to logically organise the URLs.

Each URL (or redirection) can be configured to behave in different ways. When creating a redirection there are several pieces of information you must provide:

  • Source URL - This is the original URL that you want to redirect somewhere else
  • Match - This tells the plugin how you want to match the source URL
  • Action - Determines what happens if the URL is matched
  • Regular expression - Tells the plugin that the source URL is a regular expression (i.e. a pattern that may match many URLs)
  • Target URL - most actions have a target URL. This is typically the URL that the user will be redirected to should the pattern match

Create

Note that items can be re-ordered and this may influence which redirection takes effect.

Matching URLs

Matching a URL is a key part of Redirection and consists of a source URL. This URL must exactly match a URL that you want to redirect. For example, your site has the page:

http://yoursite.com/oldpage/that/needs/redirecting/

The source URL for this is: /oldpage/that/needs/redirecting/. The source does not require your website address, and it is only possible to redirect a URL that exists on your website (you cannot redirect an external website, for example).

Advanced users can make use of regular expressions to reduce the number of redirections they need to create. A regular expression is basically a pattern that tells the plugin how to match. For example:

/(\d*)/(\d*)/(.*)

This pattern tells the plugin that you want to match a URL that looks like:

/2007/05/some-url/

That is, the (\d*) indicates a number, and the (.*) a sequence of characters. Regular expressions are a complicated subject and this page will not attempt to give more than a passing overview of using them. If you do need more help then you should take a look at a regular expression website.

Remember that if the source URL is a regular expression then you must enable the regular expression option, otherwise Redirection will just treat you source URL as plain text.

In addition to the source URL you can also specify a match condition:

  • URL only - Only matches the URL (the majority of your redirections will use this)
  • URL and referrer - Matches a URL when the source and referring site matches (i.e. match the URL only when the user came from a certain website)
  • URL and login status - Matches a URL when the source and user's login status matches (i.e. match the URL only when the user is logged in)
  • URL and user agent - Matches a URL when the source and user's browser matches (i.e. when the user is using a particular type of web browser)

These special rules can be both positive and negative. For example, you can match a URL when the user is logged in (and be redirect to one URL), or when the user is not logged in (and be redirected to another URL). This makes it very easy to create custom rules where users are redirected if they are using a particular browser, or if they came from a particular website.

Actions

An action tells Redirection what to do when a source URL is matched:

  • Redirect to URL - The default case and the majority of your redirections will use this
  • Redirect to random post - An esoteric action that may be useful to some people
  • Pass through - An advanced option that allows you to masquerade one URL as another (i.e. when the source URL is accessed it actually displays the contents of another URL without the user being aware)
  • Error (404) - Causes a 404 error to be returned
  • Do nothing - A dummy option that can be used if you just want to track accesses to a URL

Configuration of rules and actions

Depending on the particular combination of action and match rule you may be required to provide further details for a redirection.

Basic URL redirection

You can specify which HTTP code is used to redirect a URL (301, 302, or 307):

Redirect Url

A couple of examples:

  /blog/(.*) => /$1

This will match any URL that starts with /blog/, and will redirect it to the same URL but without /blog/. For example, /blog/2006/10/01/mypost will be redirected to /2006/10/01/mypost.

  /2006/month_d+/(.*) => /2006/$1/$2

This will match any URL that starts /2006/month_, and is then followed by a number. This will be redirected to the same URL, but without month_. For example, /2006/month_1/something will be redirected to /2006/1/something.

To replace a single dash in a URL with a space:

  /tags/(.*?)-(.*?) => /tags/$1%20$2

Redirect to URL by matching user agent

This allows you to configure a redirection to occur when a specific browser (the user agent) is used:

Redirect User Agent

A set of pre-defined user agents is available from the drop-down menu or you can specify your own. The user agent match is always performed using a regular expression.

Two target URLs can be specified, one for if the user agent does match, and one for if it doesn't match.

Redirect to URL by matching referrer

Similar to the user agent rule but this one looks at the referrer. That is, if a user follows a link from another site to yours, the original site is passed along by the browser (unless disabled) to your site so that you know where the user came from. Using this rule you can base your redirections upon this original site.

Redirect to URL by login status

This rule allows you to match a URL based upon the user's WordPress login status. That is, if they are logged into your site.

Support

Please direct all support questions to the Redirection support forum. Any support questions left on this page may not be answered.

Bugs & New Features

A full list of all bugs can be found in the Redirection issue tracker.

A full list of all requested features can be found in the Redirection feature tracker.

Date Current requested features
05 Nov 2008 Track deleted posts
Share This

Comments (page 20 of 48)

  1. Jonathan :

    Sep 23, 2007 9:19 pm

    John,

    the issue is that it's not auto-generating the SOURCE. I want to set the target and then have it auto-generate the SOURCE, it's doing the opposite right now.

    If set the target, but leave the source empty, it sets it to /, even if I have a value in the auto-generated field...

  2. John (author) :

    Sep 23, 2007 8:48 pm

    Jonathon, yes this is what it should do. Did you turn on auto-generated URLs in the options?

    Michael, I can't reproduce that effect - when I add an external target it is added like anything else. Is there anything non-standard about your system?

    Colin, I can't reproduce this either! The source URL should not get rewritten. A pass-thru allows you to take the contents of the target URL and make it appear at the source URL. If your URL is being rewritten then it seems to be doing a redirect.

    Chris, that is a bit beyond what Redirection offers. When you specify a full URL then Redirection will open a connection to that site and feed the data back to the browser. This is certainly not something you would want to happen frequently. If you specify a relative URL then it must be a post inside WordPress, or a file (i.e. file://path/to/your/file).

    Andrew, what did you enter into the redirection?

  3. Kirk M :

    Sep 22, 2007 8:06 am

    Alenônimo,

    This may not answer your question but just to add another side to it, I was already using Redirection when I upgraded to WP 2.3 beta 3 and then to RC1 and the plugin continued to function okay. My question to you is were you using Redirection before you upgraded at anytime? The reason I ask is that I once had a similar problem awhile back. Although the plugin installed and I could get to the plugins Admin page under "Manage", it kept throwing database errors. To solve this problem I had to use go to the Redirection options page and delete the plugin and all associated tables (whether they were there or not) using the button on the bottom of the page. I then re-installed the plugin and reactivated and everything worked fine from then on.

    Hope this helps.

  4. Alenônimo :

    Sep 22, 2007 12:01 am

    Doesn't work for me. It seems it doesn't make his tables on database, so he can't access them. :(
    By the way, I'm using WordPress 2.3 RC 1.

  5. Jonathan :

    Sep 21, 2007 1:18 pm

    John, the issue that I'm seeing is this. I want the Redirection plugin to do this...

    I have an external URL, http://www.myjoebob.com, and I want to setup a redirect for it. I want to input that as the target and have it automatically create a source ID for it. Right now, if I do that, it sets the source ID as / and no one can visit my site.

    The source URL is what needs to be automatically generated.

    Can you do this? It would be a *huge* help.

  6. Andrew Horowitz :

    Sep 20, 2007 11:47 pm

    I did as you said, turned off the same in the htaccess and now i get this:
    Error getting URL: 500 - There was a problem retrieving the feed: com.burningdoor.rsspp.resource.impl.HttpConnectionException: Error getting URL: 400 - Recursive feed redirection error: Are requests for your 'Original Feed' address — the feed that FeedBurner is checking for updates — being redirected to your FeedBurner feed? Make sure your Original Feed is provided from a web address that isn't redirected to FeedBurner.

  7. Michael David Austin :

    Sep 20, 2007 1:08 pm

    I can add a redirect to a local file, but whenever I add a redirect to an external site, I get the animated wheel and then nothing. No errors but no redirects are added to the list. When I try to change an existing redirect to point to an external site, I get this message in the DIV that used to contain the edit form for that particular redirect:

    Service Temporarily Unavailable

    The server is temporarily unable to service your request due to maintenance downtime or capacity problems. Please try again later.
    ct is added to the list. If I try to change an existing redirect to go to an external url, I get

  8. chris :

    Sep 19, 2007 7:42 pm

    HELP!

    okay, whenever I do this: CASE A
    source:/OLDURL/(.*)/
    target:/NEWURL/?kw=$1

    Compared to this: CASE B
    source:/OLDURL/(.*)/
    target:HTTP://www.FULLADDRESS.com/NEWURL/?kw=$1

    regex set to yes, method set to pass-through
    only CASE B works correctly, and passes the variable. Now, this would not be an issue, except in case B because i am listing the whole URL i guess apache does not recognize it is on my server, and creates child process, which my shared hosting environment looks at as a DOS attack whenever google trys to check my adwords ads.

  9. Colin Helvensteijn :

    Sep 19, 2007 11:06 am

    I love this plugin, I do have one issue though. Pass through redirects do not work. The source URL gets rewriten as it should, but then WordPress throws a 404 for the target URL in my face, whereas a 301 or 302 redirect with the same source and target URL's works as expected.

  10. John (author) :

    Sep 19, 2007 12:32 am

    Hi Andrew, I've updated the information on this page with an example of how to use the referrer method.

Leave a comment


XHTML: You can use these tags: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>

Home | Software | Terms & Conditions | Sitemap | John Godley © 2008
Close
E-mail It