FREE THOUGHT · FREE SOFTWARE · FREE WORLD

Home  »  Htaccess  »  A better way to use PDF files online

by 9 comments

Adobe ReaderOne of the most annoying things on the Internet for me is when I click on a link to an Adobe PDF file. For me this is annoying to the extreme because the PDF file is openened directly in your browser because of the Adobe PDF Plugin that almost all browsers have installed. If the PDF is multi-page or a larger file my browser takes forever to load and render the PDF and sometimes even freezes!

The solution I came up with is really nice, and will work for all .pdf files on your entire site, without having to change any links. It is a secure and robust solution to my pet peeve. Feel free to add any ideas or improvements using the comment form below.


Serving PDF files for Visitor Satisfaction

For me an ideal solution would be to offer me choices, such as giving me the option to:

  1. Open in an external program that I can choose, such as Acrobat
  2. Save the file on my computer without having to open it.

PDF Before and after Fix - Firefox

PDF Output Broken FirefoxPDF Plugin Not Used Firefox

PDF Before and after Fix - Internet Explorer

PDF Output Broken Internet ExplorerPDF Plugin Not Used Fix Internet Explorer

Because serving PDF files with the above options would make me happy as a visitor, I want to offer those options to visitors on my site. Here is how I do it.

.htaccess pdf rewrite example

This .htaccess mod_rewrite code goes in your sites root .htaccess file and uses a RewriteCond to make sure that the file exists, it then rewrites the request internally to the /cgi-bin/pdf.php file while adding the PDF filename as a http GET variable called file.

RewriteEngine On
RewriteBase /
RewriteCond %{REQUEST_FILENAME} -f
RewriteRule ^(.+).pdf$  /cgi-bin/pdf.php?file=$1 [L,NC,QSA]

php pdf output example

This php code is simple yet sophisticated, it simply locates the pdf file requested using the GET variable called file and then sends the pdf file directly to the clients browser, adding some HTTP headers to make a built-in browser dialog window pop-up giving the client the option to open the pdf in an external program or to save the pdf on the clients computer.


Final Working Example

Tags

November 26th, 2007

Comments Welcome

  • Andy Towler

    Why does your site play a song (The Final Countdown I think) without me asking it to? Your article talks about visitor satisfaction - I think you should consider whether this kind of thing is likely to lead to increased satisfaction or intense irritation.

  • patrick h. lauke

    two questions really:

    - what's wrong with simply using one of the standard methods that have been out there for ages to force download?

    <Files *.pdf>
    ForceType application/octet-stream
    Header set Content-Disposition attachment
    </Files>

    or just

    AddType application/octet-stream .pdf

    - if it's just something that annoys you as an end user, why not simply change it at your end? open up your standalone adobe reader, preferences, internet and untick the "Display PDF in browser" checkbox. for every user hates the default PDF behaviour there is probably another that actually really likes it and would hate this solution.

  • Steven Clark

    Interesting article, thanks for sharing.

    I do find the loud intrusive music on this page to be somewhat as irritating as the PDF issue though... sorry.

  • Emil

    Not to be a pain in the butt (I really appreciate the article) but reading the starting words "One of the most annoying things on the internet for me..." while a song you never asked to hear is blasting out of your speakers late at night is sort of ironic. And a teeny tiny flash player (set to autoplay) that took me ages to find ("What tab did that? And where on the page?") and shut off. Autoplaying sounds is a big usability no-no, as far as I and most people I know are concerned. Sorry if I sound grumpy, I was just not ready to rock. :)

  • Mark Harris

    One of the most annoying things on the Internet for me is when I click on a link to a website and it plays music at me. Especially when it's one of a number of pages I'm opening in a background and I have to go hunting for it. If you're talking about giving users choice on how to consume content, you might think about your own site.

    Otherwise, good article

  • Elaine

    It doesn't seem to work quite right if you right-click on the link & save as...which is something I do a lot of the time, if I have a hunch a link is a PDF. Any thoughts? (Because I LOVE the general idea!)

  • Saieditor

    I like this solution; but where does this pdf file go?

  • Matt

    Sounds good, but, um, I don't see the file...

  • design247

    after reading this I thought hmmm this sounds retarded so if anyone else is looking for a solution to htaccess and download a pdf or open it...

      ForceType application/octet-stream
      Header set Content-Disposition attachment
      Header set Content-Transfer-Encoding binary

    works for me .


Related Articles


My Online Tools
Popular Articles


Hacking and Hackers

The use of "hacker" to mean "security breaker" is a confusion on the part of the mass media. We hackers refuse to recognize that meaning, and continue using the word to mean someone who loves to program, someone who enjoys playful cleverness, or the combination of the two. See my article, On Hacking.
-- Richard M. Stallman









[hide]

It's very simple - you read the protocol and write the code. -Bill Joy

Except where otherwise noted, content on this site is licensed under a Creative Commons Attribution 3.0 License, just credit with a link.
This site is not supported or endorsed by The Apache Software Foundation (ASF). All software and documentation produced by The ASF is licensed. "Apache" is a trademark of The ASF. NCSA HTTPd.
UNIX ® is a registered Trademark of The Open Group. POSIX ® is a registered Trademark of The IEEE.

+Askapache | askapache

Site Map | Contact Webmaster | License and Disclaimer | Terms of Service

↑ TOPMain