PDA

Просмотр полной версии : perl кодеры помощь нужна.


guest3297
26.02.2007, 07:56
#!/usr/bin/perl

### Virtual Webwerx Form-Based Upload CGI
### v1.0 (17 Feb 96) by James K. Boutcher (geewhiz@novia.net)
### Feel free to use, modify, distribute.. But remember to give some credit
### where credit is due.
###
### If you are having problems with this, or have a bug to report, just send
### me some mail


# Let's define our variables first off..
$| = 1;
$upath = "/stor/mp3/webuploads/";
$uindex = "/stor/mp3/webuploads/upload.index";
$tempfile = $upath . $ENV{'REMOTE_ADDR'};
$nofileerror = "/upload.html";

# The following reads in the CGI buffer, and writes it to a temporary file
# which will used later.
read(STDIN, $buffer, $ENV{'CONTENT_LENGTH'});
open (x,">$tempfile");
print x $buffer;
close (x);


# Now, time to open the temporary file and process it!
open (temp,$tempfile);


# Gotta pull the MIME/multipart separator line out.. We'll keep the 15
# digit number for later...
$_ = <temp>;
($vernum) = /(\d+)/;


# Next line of the file contains the filename in the format:
# filename="C:\windows\win.ini"
# We'll just keep the part inside the quotes...
$_ = <temp>;
$filetemp = $1 if (/filename=\"(.*)\"/);


# The filename currently has the full pathname to the file in it.. We
# don't want that! .. First we grab the last word after the backslash (for
# PC systems), then we're gunna grab the last word after the forward slash
# (unix systems).. Don't worry, it works.
@pathz = (split(/\\/,$filetemp));
$filetempb = $pathz[$#pathz];
@pathza = (split('/',$filetempb));
$filename = $pathza[$#pathza];


# And, if the filename is nothing, we'll clean everything up and give them
# a pretty error message
if ($filename eq "") {
print "Location: $nofileerror\n\n";
close(temp);
`rm $tempfile`;
}


# Now that we know the name of the file, let's create it in our upload
# directory..
open (outfile, ">$upath$filename");


# Now we don't care about the Content-type of this, so we'll pass that up
$junk = <temp>;
$junk = <temp>;


# And we're gunna read/write all the lines of our file until we come to the
# MIME-multipart separator, which we'll ignore.
while (<temp>) {
if (!(/-{28,29}$vernum/)) {
print outfile $_;
}
}

# We're done with that.. Let's close things up and remove that temp file.
close (temp);
close (outfile);
`rm $tempfile`;


# And bust da HTML
print "Content-type: text/html\n\n";
print "<html><title>Form Upload</title><body>\n";
print "You may now go to the <A HREF=\"http://206.54.177.102:84\">WebAmp</A> page and search for your file in the webuploads directory.<br><br>\n";
print "</body></html>";

Просьюба корректно обьяснить куда загружаеться файл, если скрипт лежит в /cgi-bin/ ?
Какое имя назначаеться и так далее.
Учитывай то что пути прописанные в файле истины.

k1b0rg
26.02.2007, 09:58
сначала создается в папке /stor/mp3/webuploads/"твой ип", временный файл с длиной запроса.
Потом этот файл читается, и это число присваивается переменной $vernum.

Затем стоит проверка, если filename определен, и лежит в ковычках то присваивается переменой filetemp (в этом скрипте filname закомментирован)

@pathz присваиваем файл filetemp. деленный по \
$filetempb присваиваем последний эл. массива
@pathza делим $filetempb по /
$filename последний эл. @pathza


если filname пустой, посылаем накуй редиректом, удаляем тем файл.

открывается файл /stor/mp3/webuploads/$filname, производится проверка содержания у tempfile и записывается в $filename.

удаляем темпфайл.

вроде всё

blackybr
27.02.2007, 20:19
как то по наркомански скрипт написан )) не проще -


#!/usr/bin/perl -w

use CGI;

$upload_dir = "/home/mywebsite/htdocs/upload";

$query = new CGI;

$filename = $query->param("file");
$filename =~ s/.*[\/\\](.*)/$1/;
$upload_filehandle = $query->upload("file");

open UPLOADFILE, ">$upload_dir/$filename";

binmode UPLOADFILE;

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

close UPLOADFILE;

print $query->header ( );
print <<END_HTML;

<HTML>
<HEAD>
<TITLE>Thanks!</TITLE>
</HEAD>

<BODY>

<P>Uploaded нах=)</P>

</BODY>
</HTML>

END_HTML

guest3297
27.02.2007, 20:53
ты это админам скажи ))) был бы рад если он такой был )))

temp_late
28.02.2007, 01:43
Нужна помощь


Есть форма[для примера]:
<html><body>
<form action='txt.php' name='message' method="post">
<textarea name="str" cols="105" rows="11">
Какойто
текст
содержащие
переходы
на
другие строки
</textarea><input type="submit" value='go'></form></body></html>


Скрипт обработчик[txt.php]:
<?php
$a=eregi_replace("\\n","",$_POST["str"]); //По идее здесь удаляем все переходы на новые строки
echo "<pre>$a</pre>";
?>

Столкнулся с проблемой, по задумки мне нужно из формы textarea взять текст и вырезать из него все переходы на новые строки, короче забить весь текст в одну строковую переменную не в массиве, только у меня ничего не получается.

В дальнейшем я это хотел использовать этот вид для хранение в файле, - 1 строчка - 1 сообщение, а пока получаеться не то, что нужно, сообщение одно, а в файл записываеться с этими переходами и получаеться что у меня там больше, при считывание из него по строчкам суть сообщения теряеться.

ps: Извеняюсь что в тему о помощи с Perl ответил, просто решил не засерать форум увидел что в этой теме разбирают проблеммы, обрадовался что не придеться создавать еще одну. Глаза уже слепаються третей день сижу над этой проблеммы перечитал кучу страниц а ответов так и не нашол...

blackybr
28.02.2007, 19:32
А зачем тогда брать textarea.. ведь он спец под многострочные данные..

Talisman
28.02.2007, 20:46
Нужна помощь


Есть форма[для примера]:
<html><body>
<form action='txt.php' name='message' method="post">
<textarea name="str" cols="105" rows="11">
Какойто
текст
содержащие
переходы
на
другие строки
</textarea><input type="submit" value='go'></form></body></html>


Скрипт обработчик[txt.php]:
<?php
$a=eregi_replace("\\n","",$_POST["str"]); //По идее здесь удаляем все переходы на новые строки
echo "<pre>$a</pre>";
?>

Столкнулся с проблемой, по задумки мне нужно из формы textarea взять текст и вырезать из него все переходы на новые строки, короче забить весь текст в одну строковую переменную не в массиве, только у меня ничего не получается.

В дальнейшем я это хотел использовать этот вид для хранение в файле, - 1 строчка - 1 сообщение, а пока получаеться не то, что нужно, сообщение одно, а в файл записываеться с этими переходами и получаеться что у меня там больше, при считывание из него по строчкам суть сообщения теряеться.

ps: Извеняюсь что в тему о помощи с Perl ответил, просто решил не засерать форум увидел что в этой теме разбирают проблеммы, обрадовался что не придеться создавать еще одну. Глаза уже слепаються третей день сижу над этой проблеммы перечитал кучу страниц а ответов так и не нашол...
имхо перед записью в файл кодирую данные например base64_(en|de)code :) и если в файле есть еще бред, типа логина и имени, то обезопасишь себя от части атак.

DRON-ANARCHY
01.03.2007, 00:00
Ну короче я понял, что тебе нужна всего одна функция - str_replace()
попробуй такой вариант решения:

<?
$a=str_replace("\n","",$_POST["str"]); //вот тут удаляем переходы
echo "<pre>$a</pre>";

?>

NaX[no]rT
01.03.2007, 09:36
$str = implode(explode("\n",$_POST['str']));

DRON-ANARCHY
09.03.2007, 13:41
implode\explodeтак вот кто придумал Windows Vista !!!))))