• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 182
  • Last Modified:

file download and authentication

There are lots of websites offering files to be downloaded, but only after you login correctly. May I know how do I do this in cgi/perl? i.e. how to hide the path of the file? Or I have to write a script to 'stream' the file to the browser?
  • 4
  • 2
  • 2
  • +3
1 Solution
A simple suggestion is that you simply have a perl which when it recieves a file request copies it to a temp directory, starts the download and kills the file when done.... Is simple but sometimes thats the best....
open FILE,"</path/file" or die "can't open file $!";
print $query->header(-type=>'application/octet-stream');
while( <FILE> ){ print }

I assume you mead to say that wyldsj should use the CGI module like so:

use CGI;

$query = new CGI;

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

wyldsjAuthor Commented:
Thanks, both.
However,when I try the method using IE, my browser shows the file content directly (the binary rubbish). Also, I guess there must be somewhere in the script to tell the browser the file name to be downloaded. Anything missing?

Thanks again!
christopher sagayamCommented:
there are many methods
the simple one is to use cookie
so when some one registers you set
him a cookie then the script which
promt to download will check for cookie
if there is a cookie it will promt to
download else it will redirect to registration page
this way mach more faster than i saw
people wrote and it doesn't matter
weather user can see the path or not
in both cases he won't be able to download it.

there is more complicated way like
to play with file permission
but this in case you are the root of
the server if you want more information
wyldsjAuthor Commented:
>> then the script which promt to download will
>> check for cookie if there is a cookie
>> it will promt to download else it
will redirect to registration page

I am not worrying about the authentication method. I am worrying about how to write a script to "prompt to download". ozo's method works great for me except for the filename.
Well, the browser actually tends to use the last part of the download path... which means you pretty much have to use GET instead of POST.

That's how I got it to work, at any rate.

Here's an example of a URL that should name the file correctly:


Most browsers would grab something.zip as the file name.

Note, if that doesn't work, you can also use

which would put the file name in $ENV{'PATH_INFO'}
then i'm sorry you would like to explain
your self better next time  as i understood you was worry
about people who would be able to download with out registration and not how to promt to download
wyldsjAuthor Commented:
Thanks powerlord, it works!
Looks like the answer is a combination from ozo, guadalupe and powerlord. Please let me know whom I should give the credit to.

Thanks to your experts!
wyldsjAuthor Commented:
i guess this is the most important part of the answer.. :)
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Cloud Class® Course: Microsoft Office 2010

This course will introduce you to the interfaces and features of Microsoft Office 2010 Word, Excel, PowerPoint, Outlook, and Access. You will learn about the features that are shared between all products in the Office suite, as well as the new features that are product specific.

  • 4
  • 2
  • 2
  • +3
Tackle projects and never again get stuck behind a technical roadblock.
Join Now