2008-10-02 89 views

回答

7

只是一個注意事項:但是你會寫它,不要保存在一個可從您的網絡服務器訪問的地方。

現在到了一個地步:下面是我用了一段時間的照片上傳的腳本。它可能需要一些調整,但應該告訴你方式。

由於圖像沒有上傳到web-accesible目錄,因此我們有單獨的進程檢查它,調整大小,放置水印並將其放置在可以訪問的位置。

#!/usr/bin/perl -wT 

use strict; 
use CGI; 
use CGI::Carp qw (fatalsToBrowser); 
use File::Basename; 

$CGI::POST_MAX = 1024 * 5000; 
my $safe_filename_characters = "a-zA-Z0-9_.-"; 
my $upload_dir = "/home/www/upload"; 

my $query = new CGI; 
my $filename = $query->param("photo"); 
my $email_address = $query->param("email_address"); 

if (!$filename) 
{ 
print $query->header (); 
print "There was a problem uploading your photo (try a smaller file)."; 
exit; 
} 

my ($name, $path, $extension) = fileparse ($filename, '\..*'); 
$filename = $name . $extension; 
$filename =~ tr/ /_/; 
$filename =~ s/[^$safe_filename_characters]//g; 

if ($filename =~ /^([$safe_filename_characters]+)$/) 
{ 
$filename = $1; 
} 
else 
{ 
die "Filename contains invalid characters"; 
} 

my $upload_filehandle = $query->upload("photo"); 

open (UPLOADFILE, ">$upload_dir/$filename") or die "$!"; 
binmode UPLOADFILE; 

while (<$upload_filehandle>) 
{ 
print UPLOADFILE; 
} 

close UPLOADFILE; 

print $query->header (); 
print <<END_HTML; 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "DTD/xhtml1-strict.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> 
<head> 
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
    <title>Thanks!</title> 
</head> 
<body> 
    <p>Thanks for uploading your photo!</p> 
</body> 
</html> 
END_HTML 
+0

在perl5.6及更高版本中,可以將文件打開模式從文件名中分離出來,使其更「安全」,例如打開(my $ fh,「>」,$ file_name)或者「無法打開$ filename :$!「。在5.8及更高版本中,您甚至可以使用「 - |」或「| - 」,並使用數組作爲更安全的fork/execs的剩餘參數。 – runrig 2008-10-02 15:16:48

9

使用CGI module

my $fh = $query->upload('upload_field'); 
while(<$fh>) { 
    print SAVE_FILE $_; 
}