1.上传表单 upload.html
程序代码
<form enctype="multipart/form-data" action="upload.php" method="post">
<input type="hidden" name="max_file_size" value="100000">
<input name="userfile" type="file">
<input type="submit" value="上传文件">
</form>
1.注意<form enctype="multipart/form-data"......>这是一个标签,我们要实现文件的上传,必须指定为multipart/form-data,否则服务器将不知道要干什么。
2.值得注意的是文件upload.html中表单选项 MAX_FILE_SIZE 的隐藏值域,通过设置其Value(值)可以限制上载文件的大小。
3.MAX_FILE_SIZE 的值只是对浏览器的一个建议,实际上它可以被简单的绕过。因此不要把对浏览器的限制寄希望于该值。实际上,PHP 设置中的上传文件最大值,是不会失效的。但是最好还是在表单中加上 MAX_FILE_SIZE,因为它可以避免用户在花时间等待上传大文件之后才发现该文件太大了的麻烦。
PHP上传文件涉及到的参数
程序代码
$f=&$HTTP_POST_FILES['Myfile'];
$dest_dir='uploads';//设定上传目录
$dest=$dest_dir.'/'.date("ymd")."_".$f['name'];//设置文件名为日期加上文件名避免重复
$r=move_uploaded_file($f['tmp_name'],$dest);
chmod($dest, 0755);//设定上传的文件的属性
或者
<?copy($_FILES[MyFile][tmp_name],$_FILES[MyFile][name]);?>
========================================================================
以上范例中 $_FILES 数组的内容如下所示。我们假设文件上传字段的名称为 userfile(名称可随意命名)
$_FILES['userfile']['name'] 客户端机器文件的原名称。
$_FILES['userfile']['type'] 文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。
$_FILES['userfile']['size'] 已上传文件的大小,单位为字节。
$_FILES['userfile']['tmp_name'] 文件被上传后在服务端储存的临时文件名。
$_FILES['userfile']['error'] 和该文件上传相关的错误代码
值:0; 没有错误发生,文件上传成功。
值:1; 上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
值:2; 上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
值:3; 文件只有部分被上传。
值:4; 没有文件被上传。
PHP默认的上传限定是最大2M,想上传超过此设定的文件,需要调整PHP、apache等的一些参数. 下面,我们简要介绍一下PHP文件上传涉及到的一些参数:
file_uploads
是否允许通过HTTP上传文件的开关,默认为ON即是开
upload_tmp_dir
upload_tmp_dir用来说明PHP上传的文件放置的临时目录,要想上传文件,得保证服务器没有关闭临时文件和有对文件夹的写权限,如果未指定则PHP使用系统默认值
upload_max_filesize
允许上传文件大小的最大值,默认为2M
<?php define('MUILTI_FILE_UPLOAD', '10'); //最多10个文件同时上传 define('MAX_SIZE_FILE_UPLOAD', '500000' ); //文件大小不超过5MB define('FILE_UPLOAD_DIR', 'd:/'); //上传文件的目录 //允许上传的文件名 $array_extention_interdite = array( '.php' , '.php3' , '.php4' , '.exe' , '.msi' , '.htaccess' , '.gz' ); //上传文件的扩展名 //显示信息的公共函数 function func_message($message='', $ok=''){ echo '<table width="100%" cellspacing="0" cellpadding="5">'; if($ok == true){ echo '<tr bgcolor="#99FF99" ><td width="100"> </td><td class= "text"> '.$message.'</td></tr>' ; } if($ok == false){ echo '<tr bgcolor="#FF99CC" ><td width="100"> </td><td class="text"> '.$message.'</td></tr>'; } echo '</table>'; } //处理表单提交 $action = (isset($_POST['action'])) ? $_POST['action'] :'' ; $file = (isset($_POST['file'])) ? $_POST['file'] :'' ; if($file != '') { $file = $file.'/'; } $message_true = ''; $message_false = ''; switch($action){ case 'upload' : chmod(FILE_UPLOAD_DIR,0777); for($nb = 1 ; $nb <= MUILTI_FILE_UPLOAD ; $nb ++ ){ if( $_FILES['file_'.$nb]['size'] >= 10 ){ if ($_FILES['file_'.$nb]['size'] <= MAX_SIZE_FILE_UPLOAD ){ if (!in_array(ereg_replace('^[[:alnum:]]([-_.]?[[:alnum:]])*\.' ,'.', $_FILES['file_'.$nb]['name'] ) , $array_extention_interdite) ){ if($_POST['file_name_'.$nb] !=''){ $file_name_final = $_POST['file_name_'.$nb].$extension ; }else { $file_name_final = $_FILES['file_'.$nb]['name'] ; } //文件名的修改 $file_name_final = strtr($file_name_final, 'aaaaaa', 'AAAAAACEEEEIIIIOOOOOUUUUYaaaaaaceeeeiiiioooooouuuuyy'); $file_name_final = preg_replace('/([^.a-z0-1]+)/i', '_', $file_ name_final ); $_FILES['file_'.$nb]['name'] = $file_name_final; move_uploaded_file( $_FILES['file_'.$nb]['tmp_name'] , FILE_UPLOAD_ DIR . $file . $file_name_final ); $message_true .= '已经上传文件 : '.$_FILES['file_'.$nb]['name'] .'<br>'; }else{ $message_false .= '文件上传失败 : '.$_FILES['file_'.$nb]['name'] .' <br>'; } }else{ $message_false .= '文件尺寸超过'.MAX_SIZE_FILE_UPLOAD/1000 . 'KB : " '.$_FILES['file_'.$nb]['tmp_name'].'" <br>';} } }//end for break; } ?> <html> <head> <title>多文件上传</title> <style> .border{background-color:#000000} .box{background-color:#f8f8f9;} .text{ color:#000000; font-family: 宋体; font-size: 12px; font-weight:bold} input, select{font-size: 12px;} body { margin-top: 8px; } </style> <meta http-equiv="Content-Type" content="text/html; charset=gb2312"></head> <body marginwidth="0" bottommargin="0" leftmargin="0" rightmargin="0"> <form name="form" enctype="multipart/form-data" method="post" action="<?php echo $_SERVER['PHP_SELF'] ; ?>"> <input type="hidden" name="action" value="upload"> <table border="0" cellspacing="1" cellpadding="0" align="center" class="border"> <tr> <td> <?php if($message_true != '') { func_message($message_true, true); } if($message_false != ''){ func_message($message_false, false); } ?> <table width="100%" border="0" cellspacing="5" cellpadding="2" align="center" class="box"> <?php for($nb = 1 ; $nb <= MUILTI_FILE_UPLOAD ; $nb ++ ){ ?> <tr class="text"> <td>上传文件: <?php echo $nb; ?></td> <td><input type="file" name="file_<?php echo $nb; ?>"></td> <td>新文件名(包括扩展名):<?php echo $nb; ?> </td><td><input type="text" name="file_name_<?php echo $nb; ?>"></td> </tr> <?php } ?> <tr> <td colspan="2" align="right" class="text">上传目的地址:<?php echo FILE_UPLOAD_DIR ;?> <select name="file"> <option value=""></option> <?php $repertoire = opendir(FILE_UPLOAD_DIR); while( $file = readdir($repertoire) ) { $file = str_replace('.','',$file); if( is_dir($file)) { ?> <option value="<?php echo $file; ?>"> <?php echo $file; ?>/</option> <?php } } closedir($repertoire); ?> </select> </td> <td colspan="2" align="right"><input type="submit" value="可同时上传<?php echo $nb-1; ?> 个文件 "></td> </tr> </table> </td> </tr> </table> </form> </body> </html>