How to simulate Apache [END] flag on a redirect?

Javier Méndez asked:

For business-specific reasons I created the following rewrite rule for Apache 2.2.22 (mod_rewrite):

RewriteRule /site/(d+)/([^/]+).html /site/$2/$1 [R=301,L]

Which if given an URL like:

Is translated to:

That’s the expected scenario. However, there are documents which name are only numbers. So consider the following case:

Gets translated to:

Which also matches my rewrite rule pattern, so I end up with “The web page resulted in too many redirects” errors from browsers.

I have researched for a long time, and haven’t found “good” solutions. Things I tried:

  1. Use the [END] flag. Unfortunately is not available on my Apache version nor it works with redirects.

  2. Use %{ENV:REDIRECT_STATUS} on a RewriteCond clause to end the rewrite process (L). For some reason %{ENV:REDIRECT_STATUS} is empty all the times I tried.

  3. Add a response header with the Header clause if my rule matches and then check for that header (see: here for details). Seems that a) REDIRECT_addHeader is empty b) headers are can’t be set on the 301 response explicitly.

There is another alternative. I could set a query parameter to the redirect URL which indicates it comes from a redirect, but I don’t like that solution as it seems to hacky.

Is there a way to do exactly what the [END] flag does but in older Apache versions? Such as mine 2.2.22.


My answer:

The [END] flag is not relevant here, since you are serving 301 redirects. And as the documentation you linked to states…

This does not apply to new requests resulting from external redirects.

If you really need to do this sort of redirect, then you need to find some other way to disambiguate the old and new URLs.

View the full question and answer on Server Fault.

Creative Commons License
This work is licensed under a Creative Commons Attribution-ShareAlike 3.0 Unported License.