Beefy Boxes and Bandwidth Generously Provided by pair Networks
Welcome to the Monastery

Re^2: Doing a proper 404 redirect

by DreamT (Pilgrim)
on Mar 24, 2010 at 07:56 UTC ( #830475=note: print w/replies, xml ) Need Help??

in reply to Re: Doing a proper 404 redirect
in thread Doing a proper 404 redirect

Well, I'm building an architecture where Perl is supposed to handle 301:s and 404:s, opposed to handling "everything" via .htaccess (I don't like to write .htaccess dynamically)

But maybe .htaccess is the only way to go? I know it's not Perl related but...Maybe RewriteMap is a possible solution?

Replies are listed 'Best First'.
Re^3: Doing a proper 404 redirect
by afoken (Abbot) on Mar 24, 2010 at 15:03 UTC

    I think you have a problem understanding the HTTP protocol.

    Imagine you knock on a door and ask for a photo of a certain teddy bear. This is a HTTP request. Now, you could get some different responses:

    Human behind the doorStatus CodeStatus Text from RFC 2616Notes
    "OK, here you are", and hands over a pretty image200OK
    "Do you want a picture of it in the green shorts? Or with the new stylish jeans? Or in the fluffy dress? Or ..."300Multiple Choices
    "Sorry, I gave the teddy to the son of my neighboor just over the street. Ask him."301Moved PermanentlyNote that you will never see the teddy bear here again.
    "Hmm, let me think. Where did I put it? Hmmm... - Oh right, it's at the neighboor next door."302FoundNo information about how long the teddy bear will stay there.
    "Walk around the house, I'll give it to you through the front door"303See OtherRFC: For redirects from POST to GET
    "Oh, right, that teddy bear. My son has carried it into the basement, go there and ask him".307Temporary RedirectThe teddy will come back here.
    "┐Hablas espa˝ol? Parlez-vous franšais? Sprechen Sie deutsch?"400Bad Request
    "Let me see your ID card first, please"401Unauthorized
    "Hand over the money first"402Payment RequiredNo, I'm not kidding. But as no one has a working concept for payments inside HTTP, the code description has changed to "reserved for future use".
    "YOU, Sir, won't get that from me."403Forbidden
    "I don't have no stinkin' bears."404Not FoundNot here, no information if it was here before or will be here later.
    "The bear photographer? No, he doesn't live here any more. Don't know where he's gone."410GoneGone, and won't come back, like 301. But no new URL known, so no redirection.
    ***KABOOOOOM***500Internal Server Error
    "Sorry, I don't have a polaroid."501Not Implemented
    "My parents are not at home. Please come back later!"504Service Unavailable

    Is it clear now?

    What answer do you want to give? 404 means "I don't have that, and I don't know where it is." No Redirection. 301/302/303/307 means "OK, I don't have it here, but look over there." with minor differences in WHY you don't have the requested resource. Redirection follows automatically. Or the really hard 410? "It is no longer here, and it won't come back."

    Why do you think that search engines or customers need a special treatment? If a resource is not available, send 404 or perhaps 410. If it is elsewhere, send 301/302/303/307.

    If you want to help humans navigating your page when they hit a 404 page, you could add a search form, a link to a search page, a link to a site map, or links to the most wanted pages to the 404 page. Just make sure that the 404 page is larger than 1024 bytes, or else MS IE users will only see a braindead default page generated by the MS IE.


    Today I will gladly share my knowledge and experience, for there are no sweeter words than "I told you so". ;-)
      Thanks for your reply!
      Obviously, i've mixed this up with another subject:-) I wasn't supposed to talk about rewritemaps and such at all...

      The purpose of my 404:s aren't of course to redirect to another page, only to express that "this page didn't exist".

      I understand what you're writing, obviously I can print whatever content I want to, my concern is just that i want to write a correct 404 header before that.

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://830475]
[usemodperl]: i even tried to run perl again from inside script with qx and the working one liner: nada
[Corion]: Maybe the Perl you try stand-alone and the Perl you run are different?

How do I use this? | Other CB clients
Other Users?
Others meditating upon the Monastery: (6)
As of 2018-06-23 12:14 GMT
Find Nodes?
    Voting Booth?
    Should cpanminus be part of the standard Perl release?

    Results (125 votes). Check out past polls.