Wie kann ich HTTP-Datei-Uploads umgehen?
-
03-07-2019 - |
Frage
Wie würde ich ein Perl-CGI-Skript schreiben, die eine Datei über eine HTTP-Post empfängt und speichert, dass auf das Dateisystem?
Lösung
Nur eine Anmerkung:. Aber Sie es schreiben, nicht an einem Ort speichert zugänglich von Ihrem Web-Server
Und jetzt auf den Punkt: unten ist ein Skript, das ich seit einiger Zeit für Foto-Upload verwendet wurde. Es könnte einige Optimierungen benötigen, aber Sie sollten den Weg zeigen.
Wie das Bild ist nicht auf dem Web-accesible Verzeichnis hochgeladen, wir dann separaten Prozess haben es überprüft, Ändern der Größe, setzt ein Wasserzeichen und platzieren es, wo es zugegriffen werden kann.
#!/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
Andere Tipps
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow