IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

[Upload] Une page d'upload en PHP [Fait]


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Inscrit en
    Octobre 2006
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 277
    Points : 56
    Points
    56
    Par défaut [Upload] Une page d'upload en PHP
    Bonjour tout le monde

    j'essais de me faire une page d'upload ou les personnes qui vont devoir m'envoyer un fichier important auront juste a visiter cette page et je vais recevoir le fichier directement sur mon ftp.

    J'ai 2 fichiers

    Fichiers demo.html

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
     
    <html>
    <head>
    <title>Upload Lite Demo form. Copyright PerlscriptsJavaScripts.com</title>
    </head>
     
    <body>
    <font face="Arial" size="2">Each file field must be named FILEn, where n is any number. Enter the full URL to the script on your server in the Form's <b>action</b> attribute.</font>
    <p>
    <form action="/cgi-bin/upload.cgi" method="post" enctype="multipart/form-data"> 
     
    <input type="File" name="FILE1">
    <p>
    <input type="File" name="FILE44">
    <p>
    <input type="Submit" value="submit">
     
    </form> 
     
    </body>
    </html>

    Fichier upload.cgi

    Code perl : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    299
    300
    301
    302
    303
    304
    305
    306
    307
    308
    309
    310
    311
    312
    313
    314
    315
    316
    317
    318
    319
    320
    321
    322
    323
    324
    325
    326
    327
    328
    329
    330
    331
    332
    333
    334
    335
    336
    337
    338
    339
    340
    341
    342
    343
    344
    345
    346
    347
    348
    349
    350
    351
    352
    353
    354
    355
    356
    357
    358
    359
    360
    361
    362
    363
    364
    365
    366
    367
    368
    369
    370
    371
    372
    373
    374
    375
    376
    377
    378
    379
    380
    381
    382
    383
    384
    385
    386
    387
    388
    389
    390
    391
    392
    393
    394
    395
    396
    397
    398
    399
    400
    401
    402
    403
    404
    405
    406
    407
    408
    409
    410
    411
    412
    413
    414
    415
    416
    417
    418
    419
    420
    421
    422
    423
    424
    425
    426
    427
    428
    429
    430
    431
    432
    433
    434
    435
    436
    437
    438
    439
    440
    441
    442
    443
    444
    445
    446
    447
    448
    449
    450
    451
    452
    453
    454
    455
    456
    457
    458
    459
    460
    461
    462
    463
    464
    465
    466
    467
    468
    469
    470
    471
    472
    473
    474
    475
    476
    477
    478
    479
    480
    481
    482
    483
    484
    485
    486
    487
    488
    489
    490
    491
    492
    493
    494
    495
    496
    497
    498
    499
    500
    501
    502
    503
    504
    505
    506
    507
    508
    509
    510
    511
    512
    513
    514
    515
    516
    517
    518
    519
    520
    521
    522
    523
    524
    525
    526
    527
    528
    529
    530
    531
    532
    533
    534
    535
    536
    537
    538
    539
    540
    541
    542
    543
    544
    545
    546
    547
    548
    549
    550
    551
    552
    553
    554
    555
    556
    557
    558
    559
    560
    561
    562
    563
    564
    565
    566
    567
    568
    569
    570
    571
    572
    573
    574
    575
    576
    577
    578
    579
    580
    581
    582
    583
    584
    585
    586
    587
    588
    589
    590
    591
    592
    593
    594
    595
    596
    597
    598
    599
    600
    601
    602
    603
    604
    605
    606
    607
    608
    609
    610
    611
    612
    613
    614
    615
    616
    617
    618
    619
    620
    621
    622
    623
    624
    625
    626
    627
    628
    629
    630
    631
    632
    633
    634
    635
    636
    637
    638
    639
    640
    641
    642
    643
    644
    645
    646
    647
    648
    649
    650
    651
    652
    653
    654
    655
    656
    657
    658
    659
    660
    661
    662
    663
    664
    665
    666
    667
    668
    669
    670
    671
    672
    673
    674
    675
    676
    677
    678
    679
    680
    681
    682
    683
    684
    685
    686
    687
    688
    689
    690
    691
    692
    693
    694
    695
    696
    697
    698
    699
    700
    701
    702
    703
    704
    705
    706
    707
    708
    709
    710
    711
    712
    713
    714
    715
    716
    717
    718
    719
    720
    721
    722
    723
    724
    725
    726
    727
    728
    729
    730
    731
    732
    733
    734
    735
    736
    737
    738
    739
    740
    741
    742
    743
    744
    745
    746
    747
    748
    749
    750
    751
    752
    753
    754
    755
    756
    757
    758
    759
    760
    #!/usr/bin/perl --
     
    # Installation Instructions
    # <a href="http://www.perlscriptsjavascripts.com/perl/upload_lite/users_guide.html" target="_blank">http://www.perlscriptsjavascripts.co...ers_guide.html</a>
     
    # To order a custom install, please visit our "Secure order" page
    # and enter the standard installation fee in the "Custom Quote" field
     
    #################################################################### 
    #
    #	Upload Lite.
    #	©2002, PerlscriptsJavaScripts.com
    #
    #	Requirements:		Perl5 WINDOWS NT or UNIX
    #	Created:			Febuary , 2001
    #	Author: 			John Krinelos
    #	Version:			4.0
    #
    #	Based on Upload Gold, first release : September 2001
    #
    #	This script is free, as long as this header and any copyright messages 
    #	remains in tact. To remove copyright messages from public web pages you
    # 	must purchase copyright removal. 
    #	<a href="http://www.perlscriptsjavascripts.com/copyright_fees.html" target="_blank">http://www.perlscriptsjavascripts.co...ight_fees.html</a>
    #	
    #################################################################### 
     
    # START USER EDITS
     
    # absolute path to folder files will be uploaded to.
    # WINDOWS users, your path would like something like : images\\uploads
    # UNIX    users, your path would like something like : /home/www/images/uploads
    # do not end the path with any slashes and if you're on a UNIX serv, make sure
    # you CHMOD each folder in the path to 777
     
    $dir = "/path/to/demo_uploads";  
    #$dir = "d:\\html\\users\\html\\images";
     
    # absolute URL to folder files will be uploaded to
    $folder = "http://www.yourserver.com/demo_uploads";
     
    # maximum file size allowed (kilo bytes)
    $max = 100;
     
    # for security reasons, enter your domain name. 
    # this is so uploads may only occur from your domain
    # enter any part of your domain name, or leave this 
    # blank if you don't mind other web sites using your copy
    $domain = "";
     
    # if a file is successfully uploaded, enter a URL to redirect to.
    # leave this blank to have the default message printed. If using
    # this var, it must begin with http
    $redirect = "";
     
    # if you would like to be notified of uploads, enter your email address
    # between the SINGLE quotes. leave this blank if you would not like to be notified
    $notify = 'you@yourserver.com';
     
    # UNIX users, if you entered a value for $notify, you must also enter your
    # server's sendmail path. It usually looks something like : /usr/sbin/sendmail
    $send_mail_path = "/usr/sbin/sendmail";
     
    # WINDOWS users, if you entered a value for $notify, you must also enter your
    # server's SMTP path. It usually looks something like : mail.servername.com
    $smtp_path = "mail.yourserver.com";
     
    # set to 1 if you would like all files in the directory printed to the web page
    # after a successful upload (only printed if redirect is off). Set to 0 if you 
    # do not want filenames printed to web page
    $print_contents = 1;
     
    # allow overwrites? 1 = yes, 0 = no (0 will rename file with a number on the end, the 
    # highest number is the latest file)
    $overwrite = 0;
     
    # file types allowed, enter each type on a new line
    # Enter the word "ALL" in uppercase, to accept all file types.
    @types = qw~
     
    txt
    jpeg
    jpg
    gif
     
    ~;
     
    ####################################################################
    #    END USER EDITS
    ####################################################################
     
    $folder =~ s/(\/|\\)$//ig;
     
    $OS = $^O; # operating system name
    if($OS =~ /darwin/i) { $isUNIX = 1; }
    elsif($OS =~ /win/i) { $isWIN = 1; }
    else {$isUNIX = 1;}
     
    if($isWIN){ $S{S} = "\\\\"; }
    else { $S{S} = "/";} # seperator used in paths
     
    $ScriptURL = "http://$ENV{'SERVER_NAME'}$ENV{'SCRIPT_NAME'}";
     
    unless (-d "$dir"){
    	mkdir ("$dir", 0777); # unless the dir exists, make it ( and chmod it on UNIX )
    	chmod(0777, "$dir");
    }
     
    unless (-d "$dir"){
    	# if there still is no dir, the path entered by the user is wrong and the upload will fail
    	&PrintHead; #print the header
     
    	# get the Win root
    	$ENV{PATH_INFO} =~ s/\//$S{S}/gi;
    	$ENV{PATH_TRANSLATED} =~ s/$ENV{PATH_INFO}//i;
     
    	print qq~
    	<table width="600">
    	<tr>
    	<td>
     
    	<font face="Arial" size="2">
    	<b>The path you entered is incorrect.</b> You entered : "$dir"
    	<p>
    	Your root path is (UNIX): $ENV{DOCUMENT_ROOT}
    	<p>
    	Your root path is (WINDOWS): $ENV{PATH_TRANSLATED}
    	<p>
    	Your path should contain your root path followed by a slash followed by the 
    	destination folder's name. If you are on a WINDOWS server, each slash should 
    	be escaped. Eg. each seperator should look like this : \\\\
    	<p>
    	Sometimes, the root returned is not the full path to your web space. In this case
    	you should either check with your host  or if you are using an FTP client such as 
    	CuteFTP, change to the folder you are trying to upload to and look at the path you 
    	have taken. You can see this just above the list of files on your server.
    	You must use the same path in the \$dir variable.
    	</font>
     
    	</td>
    	</tr>
    	</table>
    	~;
     
    	&PrintFoot; # print the footer
    	exit;
    }
     
    use CGI; # load the CGI.pm module
    my $GET = new CGI; # create a new object
    my @VAL = $GET->param; #get all form field names
     
    foreach(@VAL){
    	$FORM{$_} = $GET->param($_); # put all fields and values in hash 
    }
     
    my @files;
    foreach(keys %FORM){
    	if($_ =~ /^FILE/){
    		push(@files, $_); # place the field NAME in an array
    	}
    }
     
    if(!$VAL[0]){
    	# no form fields
    	&PrintHead; #print the header
     
    	print qq~
    	<table width="760">
    	<tr>
    	<td>
     
    	<font face="Arial" size="2">
    	This script must be called using a form. Your form should point to this script. Your form tag must contain the following attributes : 
    	<p>
    	&lt;form <font color="#FF0000">action</font>="$ScriptURL" <font color="#FF0000">method</font>="post" <font color="#FF0000">enctype</font>="multipart/form-data"> 
    	<p>
    	The <font color="#FF0000">method</font> must equal <font color="#FF0000">post</font> and the <font color="#FF0000">enctype</font> must equal <font color="#FF0000">multipart/form-data</font>. The <font color="#FF0000">action</font> has to point to this script (on your server). If you are reading this, copy and paste the example above. It has the correct values.
    	</font>
     
    	</td>
    	</tr>
    	</table>
    	~;
     
    	&PrintFoot; # print the footer
    	exit;
    }
     
    # check domain
    if($domain =~ /\w+/){
    	if($ENV{HTTP_REFERER} !~ /$domain/i){
    		&PrintHead; #print the header
     
    		print qq~
    		<table width="600">
    		<tr>
    		<td>
     
    		<font face="Arial" size="2">
    		Invalid referrer.
    		</font>
     
    		</td>
    		</tr>
    		</table>
    		~;
     
    		&PrintFoot; # print the footer
    		exit;
    	}
    }
     
    my $failed; # results string = false
    my $selected; # num of files selected by user
     
    #################################################################### 
     
    #################################################################### 
     
    foreach (@files){
    	# upload each file, pass the form field NAME if it has a value
    	if($GET->param($_)){
     
    		# if the form field contains a file name &psjs_upload subroutine
    		# the file's name and path are passed to the subroutine 
    		$returned = &psjs_upload($_); 
     
    		if($returned =~ /^Success/i){
    			# if the $returned message begins with "Success" the upload was succssful
    			# remove the word "Success" and any spaces and we're left with the filename   
    			$returned =~ s/^Success\s+//;
    			push(@success, $returned);
    		} else {
    			# else if the word "success" is not returned, the message is the error encountered. 
    			# add the error to the $failed scalar
    			$failed .= $returned;
    		}
    		$selected++; # increment num of files selected for uploading by user
    	}
    }
     
    if(!$selected){
    	# no files were selected by user, so nothing is returned to either variable
    	$failed .= qq~No files were selected for uploading~;
    }
     
    # if no error message is return ed, the upload was successful
     
    my ($fNames, $aa, $bb, @current, @currentfiles );
     
    if($failed){
     
    	&PrintHead;	
     
    	print qq~
    	<table align="center" width="600">
    	<tr>
    	<td><font face="Arial" size="2">
     
    	One or more files <font color="#ff0000">failed</font> to upload. The reasons returned are: 
    	<p>
     
    	$failed
    	~;
     
    	if($success[0]){
    		# send email if valid email was entered
    		if(check_email($notify)){
     
    			# enter the message you would like to receive
    			my $message = qq~
    			The following files were uploaded to your server :
    			~; 
     
    			$folder =~ s/(\/|\\)$//ig;
    			foreach(@success){
    				$message .= qq~
    				$folder/$_	
    				~;
    			}
     
    			if($isUNIX){
    				$CONFIG{mailprogram} = $send_mail_path;
    				# enter your e-mail name here if you like
    				# from e-mail, from name, to e-mail, to name, subject, body
    				&send_mail($notify, 'File Upload', $notify, 'File Upload', 'Upload Notification', $message);
     
    			} else {
    				$CONFIG{smtppath} = $smtp_path;
    				&send_mail_NT($notify, 'Your Name', $notify, 'Your Name', 'Upload Notification', $message);
    			}
    		}
     
    		print qq~
    		<p>
    		The following files were <font color="#ff0000">successfully</font> uploaded :
    		<p>
    		~;	
    		foreach(@success){
    			print qq~
    			$_<p>~;
    		}
    	}
     
    	print qq~
    	</font></td>
    	</tr>
    	</table>
    	~;
     
    	&PrintFoot;	
     
    } else {
    	# upload was successful
     
    	# add a link to the file
    	$folder =~ s/(\/|\\)$//ig;
     
    	# send email if valid email was entered
    	if(check_email($notify)){
     
    		# enter the message you would like to receive
    		my $message = qq~
    		The following files were uploaded to your server :
    		~; 
     
    		foreach(@success){
    			$message .= qq~
    			$folder/$_	
    			~;
    		}
     
    		if($isUNIX){
    			$CONFIG{mailprogram} = $send_mail_path;
    			# enter your e-mail name here if you like
    			# from e-mail, from name, to e-mail, to name, subject, body
    			&send_mail($notify, 'File Upload', $notify, 'File Upload', 'Upload Notification', $message);
     
    		} else {
    			$CONFIG{smtppath} = $smtp_path;
    			&send_mail_NT($notify, 'Your Name', $notify, 'Your Name', 'Upload Notification', $message);
    		}
    	}
     
    	if($redirect){
    		# redirect user
    		print qq~Location: $redirect\n\n~;
    	} else {
    		# print success page
     
    		&PrintHead;	
     
    		print qq~
    		<table align="center" width="500">
    		<tr>
    		<th><font face="Arial" size="2"><font color="#ff0000">Success</font></font></th>
    		</tr>
    		<tr>
    		<td><font face="Arial" size="2">The following files were successfully uploaded : 
    		<p>
    		~;
     
    		foreach(@success){
    			print qq~
    			$_<p>~;
    		}
     
    		print qq~
    		</font></td>
    		</tr>
    		</table>
    		<br>
    		~;
     
    		if($print_contents){
    			print qq~
    			<table align="center" width="500">
    			<tr><td><font face="Arial" size="2"><b>Current files in folder</b></td></tr>
    			<tr>
    			<td valign="top">
    			<font face="Arial" size="2">
    			~;
     
    			opendir(DIR, "$dir");
    			@current = readdir(DIR);
    			closedir(DIR);
     
    			foreach(@current){
    				unless($_ eq '.' || $_ eq '..' || -d qq~$dir/$_~){
    					push(@currentfiles, $_);
    				}
    			}
     
    			@currentfiles = sort { uc($a) cmp uc($b) } @currentfiles;
     
    			for($aa = 0; $aa <= int($#currentfiles / 2); $aa++){
    				print qq~
    				<font color="#ff0000"><b></b> 
    				<a href="$folder/$currentfiles[$aa]" target="_blank">$currentfiles[$aa]</a></font><br>
    				~;
    			}
     
    			print qq~</font></td><td valign="top"><font face="Arial" size="2">~;
     
    			for($bb = $aa; $bb < @currentfiles; $bb++){
    				print qq~
    				<font color="#ff0000"><b></b> 
    				<a href="$folder/$currentfiles[$bb]" target="_blank">$currentfiles[$bb]</a></font><br>
    				~;
    			}
     
     
    			print qq~
    			</font></td>
    			</tr>
    			</table>~;
    		}
     
    		print qq~
    <br>
    <center><font face="Arial" size="2">
    <a href="http://www.perlscriptsjavascripts.com/?ul">&copy; PerlScriptsJavaScripts.com</a>
    &nbsp; &nbsp; 
    <a href="http://www.perlscriptsjavascripts.com/psjs_faqs/index.html?ul">F.A.Q.</a>
    &nbsp; &nbsp; 
    <a href="http://www.perlscriptsjavascripts.com/perl/upload_lite/users_guide.html?ul">Users Guide</a>
    </font></center>
    ~;
     
    		&PrintFoot;	
     
    	}
    }
     
    #################################################################### 
     
    #################################################################### 
     
    sub psjs_upload {
     
    	my ( $type_ok, $file_contents, $buffer, $destination ); # declare some vars
     
    	my $file = $GET->param($_[0]); # get the FILE name. $_[0] is the arg passed
     
    	$destination = $dir;
     
    	my $limit = $max;
    	$limit *= 1024; # convert limit from bytes to kilobytes
     
    	# create another instance of the $file var. This will allow the script to play 
    	# with the new instance, without effecting the first instance. This was a major 
    	# flaw I found in the psupload script. The author was replacing spaces in the path
    	# with underscores, so the script could not find a file to upload. He blammed the 
    	# error on browser problems.
    	my $fileName    = $file; 
     
    	# get the extension
    	my @file_type   = split(/\./, $fileName);
    	# we can assume everything after the last . found is the extension
    	my $file_type   = $file_type[$#file_type];
     
    	# get the file name, this removes everything up to and including the 
    	# last slash found ( be it a forward or back slash )
    	$fileName =~ s/^.*(\\|\/)//;
     
    	# remove all spaces from new instance of filename var 
    	$fileName =~ s/\s+//ig;
     
    	# check for any any non alpha numeric characters in filename (allow dots and dahses)
    	$fileName =~ s/\./PsJsDoT/g;
    	$fileName =~ s/\-/PsJsDaSh/g;
    	if($fileName =~ /\W/){
    		$fileName =~ s/\W/n/ig; # replace any bad chars with the letter "n"
    	}
    	$fileName =~ s/PsJsDoT/\./g;
    	$fileName =~ s/PsJsDaSh/\-/g;
     
    	# if $file_type matchs one of the types specified, make the $type_ok var true
    	for($b = 0; $b < @types; $b++){
    		if($file_type =~ /^$types[$b]$/i){
    			$type_ok++;
    		}
    		if($types[$b] eq "ALL"){
    			$type_ok++; # if ALL keyword is found, increment $type_ok var.
    		}
    	}
     
    	# if ok, check if overwrite is allowed
    	if($type_ok){
    		if(!$overwrite){ # if $overwite = 0 or flase, rename file using the checkex sub
    			$fileName = check_existence($destination,$fileName);
    		}
    		# create a new file on the server using the formatted ( new instance ) filename
    		if(open(NEW, ">$destination$S{S}$fileName")){
    			$VAR{err} .= $!;
    			if($isWIN){ binmode NEW; } else { chmod(0777, "$destination$S{S}$fileName"); }
    			# start reading users HD 1 kb at a time.
    			while (read($file, $buffer, 1024)){ 
    				# print each kb to the new file on the server 
    				print NEW $buffer; 
    			}
    			# close the new file on the server and we're done
    			close NEW;
    		} else {
    			# return the server's error message if the new file could not be created
    			return qq~Error: Could not open new file on server. $!~;
    		}
     
    		# check limit hasn't just been overshot
    		if(-s "$destination$S{S}$fileName" > $limit){ # -s is the file size
    			unlink("$destination$S{S}$fileName"); # delete it if it's over the specified limit
    			return qq~File exceeded limitations : $fileName~;
    		}
    	} else {
    		return qq~Bad file type : $file_type~; 
    	}
     
    	# check if file has actually been uploaded, by checking the file has a size
    	if(-s "$destination$S{S}$fileName"){
    		return qq~Success $fileName~; #success 
    	} else {
    		# delete the file as it has no content
    		unlink("$destination$S{S}$fileName");
    		# user probably entered an incorrect path to file
    		return qq~Upload failed : No data in $fileName. No size on server's copy of file. 
    		Check the path entered. $VAR{err}~; 
    	}
    }
     
    #################################################################### 
     
    #################################################################### 
     
    sub check_existence {
    	# $dir,$filename,$newnum are the args passed to this sub
    	my ($dir,$filename,$newnum) = @_;
     
    	my (@file_type, $file_type, $exists, $bareName); 
    	# declare some vars we will use later on in this sub always use paranthesis 
    	# when declaring more than one var! Some novice programmers will tell you 
    	# this is not necessary. Tell them to learn how to program.
     
    	if(!$newnum){$newnum = "0";} # new num is empty in first call, so set it to 0
     
    	# read dir and put all files in an array (list)
    	opendir(DIR, "$dir");
    	@existing_files =  readdir(DIR);
    	closedir(DIR);
     
    	# if the filename passed exists, set $exists to true or 1
    	foreach(@existing_files){
    		if($_ eq $filename){
    			$exists = 1;
    		}
    	}
     
    	# if it exists, we need to rename the file being uploaded and then recheck it to 
    	# make sure the new name does not exist
    	if($exists){
    		$newnum++; # increment new number (add 1)
     
    		# get the extension
    		@file_type   = split(/\./, $filename); # split the dots and add inbetweens to a list
    		# put the first element in the $barename var
    		$bareName    = $file_type[0]; 
    		# we can assume everything after the last . found is the extension
    		$file_type   = $file_type[$#file_type]; 
    		# $#file_type is the last element (note the pound or hash is used)
     
    		# remove all numbers from the end of the $bareName
    		$bareName =~ s/\d+$//ig;
     
    		# concatenate a new name using the barename + newnum + extension 
    		$filename = $bareName . $newnum . '.' . $file_type;
     
    		# reset $exists to 0 because the new file name is now being checked
    		$exists = 0;
     
    		# recall this subroutine
    		&check_existence($dir,$filename,$newnum);
    	} else {
    		# the $filename, whether the first or one hundreth call, now does not exist
    		# so return the name to be used
    		return ($filename);
    	}
    }
     
    #################################################################### 
     
    #################################################################### 
     
    sub send_mail {
    	my ($from_email, $from_name, $to_email, $to_name, $subject, $message ) = @_;
     
    	if(open(MAIL, "|$CONFIG{mailprogram} -t")) {
    		print MAIL "From: $from_email ($from_name)\n";
    		print MAIL "To: $to_email ($to_name)\n";
    		print MAIL "Subject: $subject\n";
    		print MAIL "$message\n\nSubmitter's IP Address : $ENV{REMOTE_ADDR}";
    		close MAIL;
    		return(1);
    	} else {
    		return;
    	}
    }
     
    #################################################################### 
     
    #################################################################### 
     
    sub send_mail_NT {
     
    	my ($from_email, $from_name, $to_email, $to_name, $subject, $message ) = @_;
     
    	my ($SMTP_SERVER, $WEB_SERVER, $status, $err_message);
    	use Socket; 
        $SMTP_SERVER = "$CONFIG{smtppath}";                                 
     
    	# correct format for "\n"
        local($CRLF) = "\015\012";
        local($SMTP_SERVER_PORT) = 25;
        local($AF_INET) = ($] > 5 ? AF_INET : 2);
        local($SOCK_STREAM) = ($] > 5 ? SOCK_STREAM : 1);
        local(@bad_addresses) = ();
        $, = ', ';
        $" = ', ';
     
        $WEB_SERVER = "$CONFIG{smtppath}\n";
        chop ($WEB_SERVER);
     
        local($local_address) = (gethostbyname($WEB_SERVER))[4];
        local($local_socket_address) = pack('S n a4 x8', $AF_INET, 0, $local_address);
     
        local($server_address) = (gethostbyname($SMTP_SERVER))[4];
        local($server_socket_address) = pack('S n a4 x8', $AF_INET, $SMTP_SERVER_PORT, $server_address);
     
        # Translate protocol name to corresponding number
        local($protocol) = (getprotobyname('tcp'))[2];
     
        # Make the socket filehandle
        if (!socket(SMTP, $AF_INET, $SOCK_STREAM, $protocol)) {
            return;
        }
     
    	# Give the socket an address
    	bind(SMTP, $local_socket_address);
     
    	# Connect to the server
    	if (!(connect(SMTP, $server_socket_address))) {
    		return;
    	}
     
    	# Set the socket to be line buffered
    	local($old_selected) = select(SMTP);
    	$| = 1;
    	select($old_selected);
     
    	# Set regex to handle multiple line strings
    	$* = 1;
     
        # Read first response from server (wait for .75 seconds first)
        select(undef, undef, undef, .75);
        sysread(SMTP, $_, 1024);
    	#print "<P>1:$_";
     
        print SMTP "HELO $WEB_SERVER$CRLF";
        sysread(SMTP, $_, 1024);
    	#print "<P>2:$_";
     
    	while (/(^|(\r?\n))[^0-9]*((\d\d\d).*)$/g) { $status = $4; $err_message = $3}
    	if ($status != 250) {
    		return;
    	}
     
    	print SMTP "MAIL FROM:<$from_email>$CRLF";
     
    	sysread(SMTP, $_, 1024);
    	#print "<P>3:$_";
    	if (!/[^0-9]*250/) {
    		return;
    	}
     
        # Tell the server where we're sending to
    	print SMTP "RCPT TO:<$to_email>$CRLF";
    	sysread(SMTP, $_, 1024);
    	#print "<P>4:$_";
    	/[^0-9]*(\d\d\d)/;
     
    	# Give the server the message header
    	print SMTP "DATA$CRLF";
    	sysread(SMTP, $_, 1024);
    	#print "<P>5:$_";
    	if (!/[^0-9]*354/) {
    		return;
    	}
     
    	$message =~ s/\n/$CRLF/ig;
     
    	print SMTP qq~From: $from_email ($from_name)$CRLF~;
    	print SMTP qq~To: $to_email ($to_name)$CRLF~;
    	if($cc){
    		print SMTP "CC: $cc ($cc_name)\n";
    	}
    	print SMTP qq~Subject: $subject$CRLF$CRLF~;
    	print SMTP qq~$message~;
     
    	print SMTP "$CRLF.$CRLF";
    	sysread(SMTP, $_, 1024);
    	#print "<P>6:$_";
    	if (!/[^0-9]*250/) {
    		return;
    	} else {
    		return(1);
    	}
     
    	if (!shutdown(SMTP, 2)) {
    		return;
        } 
    }
     
    #################################################################### 
     
    #################################################################### 
     
    sub PrintHead {
    	print qq~Content-type: text/html\n\n~;
    	print qq~
    	<html>
    	<title>PerlScriptsJavascript.com Free upload utility</title>
    	<body bgcolor="#ffffff">
    	~;
    }
     
    #################################################################### 
     
    #################################################################### 
     
    sub PrintFoot {
    	print qq~
    	</body>
    	</html>
    	~;
    }
     
    #################################################################### 
     
    #################################################################### 
     
    sub check_email {
    	my($fe_email) = $_[0];
    	if($fe_email) {
    		if(($fe_email =~ /(@.*@)|(\.\.)|(@\.)|(\.@)|(^\.)|(\.$)/) ||
    		($fe_email !~ /^.+@\[?(\w|[-.])+\.[a-zA-Z]{2,4}|[0-9]{1,3}\]?$/)) {
    			return;
    		} else { return(1) }
    	} else {
    		return;
    	}
    }


    Je cherche quelqu'un qui peut m'aider

    Voici le tutoriaux. Je comprend rien en anglais

    Upload Lite Quick Installation
    =======================================================================
    Step 1
    Open and set the correct path to Perl on your web server in
    upload.cgi file (i.e. #!/usr/bin/perl). This is the
    first line of code in upload.cgi. Most users will be
    able to ignore this step. Windows servers do not require it.

    Edit the variables found on line 45 to 95. These are
    self-explanatory and contain instructions adjacent to each variable.

    Step 2
    Upload the upload.cgi file to your cgi-bin or any cgi enabled
    directory and CHMOD it to 755. If you do NOT upload in ASCII
    mode, expect a server 500 error.

    Step 3
    Open demo.html and make sure the form tag's action attribute
    points to the upload.cgi script you uploaded in Step 2.

    Step 4
    Upload the demo.html file to any publicly accessible directory.
    Upload it in ASCII mode also.

    Step 5
    Load your Browser, point it to the demo.html file and test
    the script by submitting the form.

  2. #2
    Expert éminent sénior
    Avatar de mathieu
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    10 440
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 10 440
    Points : 15 814
    Points
    15 814
    Par défaut
    Pour faire de l'upload avec PHP tu n'as pas besoin d'un script Perl
    regarde le tutoriel suivant :
    http://antoine-herault.developpez.co...ls/php/upload/

  3. #3
    Membre du Club
    Inscrit en
    Octobre 2006
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 277
    Points : 56
    Points
    56
    Par défaut
    J'ai tout fait dans l'ordre et cela me donne une erreur

    Warning: move_uploaded_file(upload/darkenphat.jpg) [function.move-uploaded-file]: failed to open stream: Permission denied in /home/crazycri/public_html/upload.php on line 24

    Warning: move_uploaded_file() [function.move-uploaded-file]: Unable to move '/tmp/phpnbhtSC' to 'upload/darkenphat.jpg' in /home/crazycri/public_html/upload.php on line 24
    Echec de l'upload !



    Voici les codes des fichiers

    upload.html

    upload.html


    upload.php

    upload.php

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Août 2006
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 48
    Points : 38
    Points
    38
    Par défaut
    As tu bien mis tes permissions sur le repertoire d'upload en
    CHMO 777

  5. #5
    Membre du Club
    Inscrit en
    Octobre 2006
    Messages
    277
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 277
    Points : 56
    Points
    56
    Par défaut
    HAAAAAAAAAAAA!!!



    Merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. uploader une page php
    Par ponyboy dans le forum Langage
    Réponses: 2
    Dernier message: 27/05/2010, 03h17
  2. Réponses: 4
    Dernier message: 24/08/2007, 16h56
  3. Réponses: 2
    Dernier message: 15/08/2007, 00h35
  4. [Upload] Problèmes page d'upload
    Par oxbow_337 dans le forum Langage
    Réponses: 3
    Dernier message: 02/07/2007, 14h24
  5. recharger une page dans du code php
    Par pas30 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 09/05/2007, 09h38

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo