>백엔드 개발 >PHP 튜토리얼 >php文件上传的例子及参数详解_PHP

php文件上传的例子及参数详解_PHP

WBOY
WBOY원래의
2016-06-01 11:57:52812검색

1.上传表单 upload.html

程序代码
HTML
复制代码 代码如下:

 
 
   
 
 

1.注意

这是一个标签,我们要实现文件的上传,必须指定为multipart/form-data,否则服务器将不知道要干什么。
2.值得注意的是文件upload.html中表单选项 MAX_FILE_SIZE 的隐藏值域,通过设置其Value(值)可以限制上载文件的大小。
3.MAX_FILE_SIZE 的值只是对浏览器的一个建议,实际上它可以被简单的绕过。因此不要把对浏览器的限制寄希望于该值。实际上,PHP 设置中的上传文件最大值,是不会失效的。但是最好还是在表单中加上 MAX_FILE_SIZE,因为它可以避免用户在花时间等待上传大文件之后才发现该文件太大了的麻烦。

PHP上传文件涉及到的参数

程序代码
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);//设定上传的文件的属性 

或者
复制代码 代码如下:

以上范例中 $_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 '

'; 
if($ok == true){ 
echo '' ; 
}  // www.bitsCN.com
if($ok == false){ 
echo ''; 

echo '
'.$message.'
'.$message.'
';    

//处理表单提交 
$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 if( $_FILES['file_'.$nb]['size'] >= 10 ){  
  if ($_FILES['file_'.$nb]['size'] 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'] .'
'; 
                }else{ 
                    $message_false .= '文件上传失败 : '.$_FILES['file_'.$nb]['name'] .'
'; 
                } 
                }else{ 
                    $message_false .= '文件尺寸超过'.MAX_SIZE_FILE_UPLOAD/1000 . 'KB : "                               '.$_FILES['file_'.$nb]['tmp_name'].'"
';} 
                } 
    }//end for 
    break; 

?> 
 
 
多文件上传 
 
 
 
 
 
 
 
 
if($message_true != '') {  func_message($message_true, true); } 
if($message_false != ''){  func_message($message_false, false); } 
?> 
 
for($nb = 1 ; $nb ?> 
 
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.