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

11 Responses to “WordPress, Permalinks, Mod_Rewrite, and Avoiding 404s”

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

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

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

  4. 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.

  5. 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.

  6. @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

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

  8. 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/

Trackbacks

User contributed tags for this post:

wordpress mod_rewrite (555) - wordpress permalinks 404 (493) - wordpress permalink 404 (282) - wordpress permalinks mod_rewrite (176) - mod_rewrite wordpress (145) - wordpress mod_rewrite 404 (113) - wordpress rewrite 404 (100) - wordpress permalinks apache (98) - wordpress permalink mod_rewrite (79) - wordpress mod rewrite (77) - wordpress template_redirect (71) - permalinks wordpress 404 (68) - mod_rewrite 404 redirect (65) - apache permalinks (63) - mod_rewrite wordpress permalinks (62) - mod_rewrite permalinks (59) - apache mod_rewrite wordpress (56) - wordpress 404 permalink (56) - wordpress permalink apache (55) - mod rewrite wordpress (54) - permalinks mod_rewrite (51) - mod_rewrite leopard (50) - wordpress apache rewrite (50) - wordpress apache mod_rewrite (49) - wordpress permalinks mod rewrite (47) - wordpress permalinks 403 (47) - wordpress permalink rewrite (45) - wordpress 404 permalinks (42) - wordpress permalink 403 (42) - mod_rewrite errordocument (42) - mod_rewrite redirect 404 (41) - wordpress subdirectory 404 (40) - wordpress 404 rewrite (39) - wordpress 404 hook (39) - wordpress apache permalinks (39) - apache wordpress Permalink (38) - wordpress permalinks rewrite (36) - mod_rewrite 404 (34) - wordpress mod_rewrite permalinks (34) - rewrite wordpress (32) - leopard mod_rewrite (31) - permalinks apache (31) - wordpress permalinks broken (30) - Permalink wordpress 404 (30) - rewrite 404 (29) - wordpress 404 mod_rewrite (29) - apache wordpress permalinks (28) - mod rewrite 404 (27) - wordpress permalink 404 error (27) - mod rewrite 404 redirect (26) - mod_rewrite permalinks wordpress (26) - permalinks wordpress apache (26) - apache rewrite wordpress (25) - permalink apache (25) - permalink 404 wordpress (22) - mod rewrite ErrorDocument (21) - mod rewrite permalinks (21) - wordpress mod rewrite 404 (21) - mod_rewrite wordpress 404 (21) - mod_rewrite wordpress (20) - permalinks wordpress mod_rewrite (20) - permalinks 404 (19) - WordPress 404 subdirectory (19) - wordpress template_redirect 404 (19) - mod_rewrite permalink (19) - permalinks mod rewrite (18) - wordpress permalinks apache2 (18) - wordpress permalinks error 404 (18) - mod_Rewrite 404 wordpress (18) - Wordpress permalinks 404 error (17) - wordpress permalinks 404 apache (17) - wordpress permalinks without mod_rewrite (17) - wordpress apache permalink (17) - mod rewrite avoid 404 processing (16) - apache2 wordpress (16) - wordpress 403 (16) - apache wordpress rewrite (16) - wordpress (15) - mod rewrite redirect 404 (15) - apache2 wordpress rewrite (15) - wordpress hook 404 (15) - wordpress apache2 rewrite (15) - wordpress rewrite permalinks (15) - wordpress mod_rewrite apache (15) - wordpress apache2 (14) - wordpress 404 apache (14) - rewrite permalinks (14) - wordpress permalinks (13) - rewrite wordpress 404 (13) - 404 wordpress permalinks (13) - wordpress modrewrite (13) - permalink 404 (13) - mod_rewrite for wordpress (13) - permalinks 404 wordpress (13) - modrewrite wordpress (12) - mod rewrite for wordpress (12) - wordpress permalink broken (12) - apache2 wordpress permalink (12) - wordpress permalinks leopard (12) - wordpress permalink error 404 (12) - wordpress permalink mod rewrite (11) - mod rewrite leopard (11) - wordpress permalink apache2 (11) - wordpress permalinks htaccess (11) - template_redirect wordpress (11) - mod_rewrite wordpress subdirectory (11) - apache rewrite 404 (10) - permalink wordpress apache (10) - wordpress internal rewrite (10) - mod rewrite wordpress permalinks (10) - F (10) - apache2 wordpress permalinks (10) - mod_rewrite and wordpress (10) - mod_rewrite wordpress Permalink (10) - permalinks 403 (10) - mod_rewrite apache wordpress (9) - htaccess leopard (9) - mod_rewrite .htaccess wordpress (9) - wordpress rewrite apache2 (9) - permalinks wordpress 403 (9) - wordpress rewrite permalink (9) - permalink 403 (9) - wordpress and mod_rewrite (9) - mod_rewrite wordpress plugin (9) - errordocument mod rewrite (8) - rewrite redirect 404 (8) - errordocument mod_rewrite (8) - wordpress leopard permalinks (8) - apache2 rewrite 404 (8) - mod_rewrite in wordpress (8) - permalinks wordpress mac (8) - permalinks rewrite (8) - permalink wordpress 403 (8) - wordpress permalink 403 error (8) - wordpress without mod_rewrite (8) - redirect 404 mod_rewrite (8) - apache2 mod_rewrite wordpress (8) - wordpress mod_rewrite plugin (8) - permalink apache wordpress (7) - leopard htaccess (7) - wordpress rewrite (7) - wordpress mod rewrite permalinks (7) - mod rewrite for wordpress permalinks (7) - wordpress rewrite apache (7) - wordpress permalink mac (7) - Apache mod_rewrite permalinks (7) - permalinks wordpress leopard (7) - wordpress permalink error 403 (7) - 404 Permalinks wordpress (7) -