WordPress, Permalinks, Mod_Rewrite, and Avoiding 404s

I made a mistake in changing my WordPress permalinks, but by the time I’d discovered it my blog had already been indexed. Fixing the permalinks meant breaking those indexed URLs, leading to a bad user experience, but leaving them as is wasn’t really an option.

Last night, after getting 404′d while using Google to search my own blog, I realized I had to do something.

First I looked at Apache mod_rewrite and the URL rewriting guide (as well as this cheat sheet from ilovejackdaniels), Then, frustrated, I found some items in the WordPress Codex, including this one about conflicts between .htaccess files/rules and this about problems with subdirectories inside the WordPress root.

The suggestions in both boil down to creating a specific error document:

Create a file on your website. Call it onerror.html. It can be empty or have just <html></html> in it for all that it matters.

In Wordpress’s .htaccess file, add this to the top of the file:
ErrorDocument 401 /path/to/onerror.html
ErrorDocument 403 /path/to/onerror.html

The explanation, though even the poster doesn’t claim to know that it’s the correct explanation, is that the rules are additive, and WordPress is greedy with trying to get requests directed to its own URL parsing routines. The ErrorDocument is supposed to keep more of the processing in mod_rewrite.

But after all that, and only limited success achieving what I wanted, I realized that what I really wanted was not to parse requests before WordPress had a chance at them (as would happen with rewrite rules), but to handle requests that WordPress’ internal rules couldn’t match.

What I ended up doing is writing a tiny plugin that hooked into the template_redirect hook. The short of it is that if WordPress thinks it’s 404′d, and I can divine some meaning from the requested URL, then I redirect to browser (including a HTTP/1.1 301 Moved Permanently statement). Voila, it works.

wordpress, rewrite, mod_rewrite, rewrite rules, apache rewrite, permalinks, redirect, 404

9 Comments

  1. hot damn, I would like to see this.

  2. See it? It’s in use now.

    Examples

    The URL to this post
    http://maisonbisson.com/blog/post/11617/

    Some broken URLs to this post:
    http://maisonbisson.com/blog/post/11617/wordpress-permalinks-mod_rewrite
    http://maisonbisson.com/blog/post/11617/asdasdasd

  3. Can you publish your code? I’m interested in this as well.

  4. i need please a username n’ password of google earth pro

  5. Can you explain a little bit more about what you did or show some code or anything?
    I’m really interested because I’m having same kind of 404’s errors.

    Thanks in advance.

  6. Hi,

    I would like to know the code what you implemented to redirect 404 by not invoking any query, as my site is going down often due to some ips accessing non existent urls. if you can provide me the code it would be a great help for me.

  7. @smartdesis: the method discussed here likely creates additional load on the server for 404s. You might, however, be interested in this discussion: http://maisonbisson.com/blog/post/12035/wordpress-invalid-urls-extra-database-queries

  8. Hi, on my wordpress, i have searched a lot, but not found any .htaccess file there, please tell me how wordpress do mode-rewite.

  9. Thanks for the info – You totally helped me solve my problem. I spent hours on this,
    so I decided to spend 20 mins and blog about .. here’s what i did exactly
    http://chadnorwood.com/2008/12/02/wordpress-template_redirect/


Comments RSS TrackBack Identifier URI

Leave a comment

 

User contributed tags for this post:

wordpress permalinks 404 (273) - wordpress mod_rewrite (235) - wordpress permalink 404 (159) - wordpress permalinks mod_rewrite (84) - mod_rewrite wordpress (63) - wordpress mod rewrite (60) - mod_rewrite leopard (50) - wordpress mod_rewrite 404 (46) - mod_rewrite 404 redirect (44) - wordpress permalink mod_rewrite (41) - wordpress permalinks apache (40) - mod_rewrite permalinks (39) - wordpress template_redirect (39) - wordpress rewrite 404 (35) - mod rewrite wordpress (32) - rewrite wordpress (32) - permalinks mod_rewrite (32) - wordpress permalink apache (32) - wordpress permalink rewrite (31) - mod_rewrite redirect 404 (30) - leopard mod_rewrite (29) - wordpress permalinks 403 (28) - mod_rewrite errordocument (26) - wordpress permalinks mod rewrite (25) - mod rewrite 404 (25) - mod rewrite 404 redirect (24) - wordpress 404 permalinks (23) - wordpress permalink 403 (23) - mod_rewrite 404 (23) - apache permalinks (23) - wordpress 404 permalink (23) - rewrite 404 (22) - mod_rewrite wordpress (20) - permalinks wordpress 404 (19) - mod rewrite ErrorDocument (18) - wordpress apache mod_rewrite (18) - mod_rewrite wordpress permalinks (17) - wordpress 404 mod_rewrite (17) - mod rewrite avoid 404 processing (16) - wordpress mod_rewrite permalinks (16) - wordpress permalinks rewrite (16) - wordpress (15) - mod rewrite permalinks (15) - wordpress 403 (15) - wordpress mod rewrite 404 (14) - permalinks 404 (14) - wordpress apache rewrite (14) - permalinks mod rewrite (13) - mod rewrite redirect 404 (13) - permalink 404 (13) - Permalink wordpress 404 (13) - wordpress permalinks (12) - mod_rewrite permalinks wordpress (12) - permalinks apache (12) - wordpress 404 rewrite (12) - wordpress 404 hook (12) - mod rewrite leopard (11) - wordpress permalinks broken (11) - permalink apache (11) - wordpress permalinks leopard (11) - wordpress permalinks error 404 (11) - permalinks 404 wordpress (11) - modrewrite wordpress (10) - wordpress internal rewrite (10) - mod rewrite for wordpress (10) - F (10) - mod_rewrite wordpress 404 (10) - apache mod_rewrite wordpress (10) - wordpress permalinks htaccess (10) - wordpress apache2 (10) - permalink 404 wordpress (10) - mod_Rewrite 404 wordpress (10) - wordpress apache permalinks (10) - apache wordpress Permalink (10) - htaccess leopard (9) - mod_rewrite .htaccess wordpress (9) - wordpress permalink mod rewrite (9) - wordpress permalink apache2 (9) - Wordpress permalinks 404 error (9) - permalinks wordpress apache (9) - wordpress 2.7 permalinks broken (9) - permalinks apache wordpress (9) - rewrite wordpress 404 (8) - wordpress leopard permalinks (8) - WordPress 404 subdirectory (8) - apache2 wordpress permalink (8) - apache wordpress permalinks (8) - wordpress apache permalink (8) - leopard htaccess (7) - rewrite redirect 404 (7) - template_redirect wordpress (7) - permalinks wordpress leopard (7) - wordpress permalinks without mod_rewrite (7) - rewrite permalinks (7) - mod_rewrite wordpress Permalink (7) - wordpress rewrite permalinks (7) - wordpress invalid permalinks (7) - handle 404 with mod_rewrite (6) - wordpress 2 2 apache rewrite (6) - permalink wordpress apache (6) - wordpress avoiding 404 google permalinks (6) - apache2 rewrite 404 (6) - apache2 wordpress (6) - wordpress permalinks apache2 (6) - permalinks wordpress mac (6) - permalink 403 (6) - wordpress permalink error 403 (6) - redirect 404 mod_rewrite (6) - wordpress rewrite (5) - apache rewrite wordpress (5) - errordocument mod rewrite (5) - wordpress rewrite rules (5) - mod rewrite html it (5) - WordPress 2 permalinks mod rewrite htaccess (5) - wordpress subdirectory 404 (5) - mod rewrite for wordpress permalinks (5) - ErrorDocument wordpress (5) - mod rewrite wordpress permalinks (5) - mod rewrite wordpress 404 (5) - ErrorDocument rewrite (5) - leopard mod rewrite (5) - wordpress permalink subdirectory (5) - permalinks wordpress 403 (5) - apache2 wordpress permalinks (5) - wordpress rewrite permalink (5) - mod rewrite 403 (5) - wordpress permalinks 404 apache (5) - mod_rewrite permalink (5) - wordpress permalink 404 error (5) - mod_rewrite error document (5) - wordpress permalink error 404 (5) - .htaccess wordpress leopard server (5) - apache2 mod_rewrite wordpress (5) - wordpress mod_rewrite permalink (5) - Wordpress Rewrite error (5) - how to wordpress mod_rewrite (5) - wordpress 404 subdirectory .htaccess (5) - wordpress permalinks mac (4) - apache rewrite 404 (4) - wordpress apache 2 2 rewrite (4) - wordpress search redirect mod rewrite (4) - wordpress mod rewrite permalinks (4) - mod rewrite permalink (4) - wordpress 404 redirect (4) - wordpress permalinks rewrite rules (4) - permalink mod rewrite (4) - apache2 mod rewrite wordpress (4) - apache2 wordpress rewrite (4) - mod_rewrite apache leopard (4) -