Solved

PHP Upload File by URL method

Posted on 2009-04-15
8
1,407 Views
Last Modified: 2012-05-06
Hi all,

I'd like to know, if is possible to upload files by passing the path of the file by URL example:

http://www.mysite.com/uploader.php?filename=C:\FilePath\Filename.ext

Then, the uploader.php do the entire process to upload that file...

Is it possible?

My software generate a error report, with some asm info about the error and some other info about the hardware and etc... then like Windows Reporting Tool does, the user will can send the error to us... the error file is called dbghelper.dat and i want to it by php since it use port 80 and firewall will not block it, like some firewalls is configured to do on SMTP Port, FTP Port :(

Thanks in advance :D
and sorry for bad english :(

Best Regards,
Carlos
0
Comment
Question by:cebasso
  • 2
  • 2
  • 2
8 Comments
 
LVL 108

Expert Comment

by:Ray Paseur
ID: 24147743
I do not think you can do this -- the $_FILES array needs to be populated for file uploads and it cannot be populated via GET in the URL - it would be a security exposure.
0
 
LVL 36

Expert Comment

by:Loganathan Natarajan
ID: 24147858
You cannot copy a file to the server through URL because the file stream could not parsed through the HTTP ... you need to use <FORM>
0
 
LVL 4

Author Comment

by:cebasso
ID: 24147916
Humm ok
Anyway, the is a method to to something like that in the Code Snippet.. ?!
By passing the file path by URL, do a submit automatically....
Best Regards!!
Carlos

/* upload.php */
 

<?
 

$POST_URL = "uploaded.php";

$FILENAME = $_GET["filename"];
 

?>
 

<html>

<head>

</head>

<body>
 

<form name="return" action="<? echo $POST_URL?>" method="post" enctype="multipart/form-data"> 

<input type="hidden" name="filename" value="<? echo $FILENAME?>"> 

</form>
 

<script language="JavaScript" type="text/javascript"> 

document.return.submit(); 

</script>
 

</body>

</html>
 
 

/* uploader.php */
 

<?

if (!empty($filename) and is_file($filename)) {

$path="/home/cebasso/public_html/upload/";

$path=$path.$filename;
 

if ((eregi(".gif$", $filename_name)) || (eregi(".jpg$", $filename_name))){

copy($filename, $path);

print "<h1><center>Sucess!</center></h1>";

}

else{

print "<h1><center>Error!</center></h1>";

}

}

?>

Open in new window

0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 
LVL 36

Expert Comment

by:Loganathan Natarajan
ID: 24148020
I don't think so, this will work.. as again, you are not sending the actual file stream ... you are just passing the file location to it..

have you tried this?
0
 
LVL 4

Author Comment

by:cebasso
ID: 24148112
yes i tried like below
i put the files upload.php and uploader.php in the Server
on Internet Explorer i called
http://www.mysite.com/upload.php?filename=C:\somepic.gif
but i got just a blank page, because i think my php script is wrong... i dont know PHP Programming well, just a little... smls :))
is that script correct? :D
i thin not :(
:D
0
 
LVL 108

Accepted Solution

by:
Ray Paseur earned 500 total points
ID: 24153087
@cebasso: There is a difference between uploading a file and reading a file stream.  If you read a file stream from, for example, a PHP script, you will get the generated HTML, not the PHP code.  If that is OK with you, then you might try something like this...

Test it here:
http://www.laprbass.com/RAY_get_file_from_url.php?f=RAY_get_file_from_url.php
http://www.laprbass.com/RAY_get_file_from_url.php?f=http://www.google.com

Best regards, ~Ray
<?php // RAY_get_file_from_url.php

error_reporting(E_ALL);

echo "<pre>";
 

// IF WE HAVE A GET ARGUMENT

if (empty($_GET["f"]))                      die("MISSING URL ARGUMENT 'f='");

if (!$data = file_get_contents($_GET["f"])) die("CANNOT GET {$_GET["f"]}");
 

// SHOW THE FILE WE GOT

echo htmlentities($data);

Open in new window

0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Foreword (July, 2015) Since I first wrote this article, years ago, a great many more people have begun using the internet.  They are coming online from every part of the globe, learning, reading, shopping and spending money at an ever-increasing ra…
Build an array called $myWeek which will hold the array elements Today, Yesterday and then builds up the rest of the week by the name of the day going back 1 week.   (CODE) (CODE) Then you just need to pass your date to the function. If i…
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn how to count occurrences of each item in an array.

920 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

18 Experts available now in Live!

Get 1:1 Help Now