php文件上传原理
时间:2010-03-19 来源:wusiliang
1.form标签enctype属性 表单中enctype="multipart/form-data"的意思,是设置表单的MIME编码。默认情况,这个编码格式是application/x-www-form-urlencoded,不能用于文件上传;只有使用了multipart/form-data,才能完整的传递文件数据 2.$_FILES系统函数 $_FILES['myFile']['name']客户端文件的原名称 $_FILES['myFile']['type']文件的MIME类型 $FILES['myFile']['size']已上传文件的大小 $FILES['myFile']['tmp_name']储存的临时文件名,一般为系统默认 $_FILES['myFile']['error']该文件上传到相关的错误代码 3.move_upload_file函数 上传后移动文件到目标位置的函数 move_uploaded_file(临时文件,目标位置); 4.is_uploaded_file函数 判断上传文件的类型 is_uploaded_file(MIME); 小例子: Code: 1. <HTML> 2. <HEAD> 3. <TITLE>Figure 7-3</TITLE> 4. </HEAD> 5. <BODY> 6. <? 7. //check for file upload 8. if(isset($UploadedFile)) 9. { 10. unlink($UploadedFile); 11. print("Local File: $UploadedFile <BR>\n"); 12. print("Name: $UploadedFile_name <BR>\n"); 13. print("Size: $UploadedFile_size <BR>\n"); 14. print("Type: $UploadedFile_type <BR>\n"); 15. print("<HR>\n"); 16. } 17. ?> 18. 19. <FORM ENCTYPE="multipart/form-data" ACTION="7-3.php3" METHOD="post"> 20. <INPUT TYPE="hidden" name="MAX_FILE_SIZE" value="4096"> 21. <INPUT NAME="UploadedFile" TYPE="file"> 22. <INPUT TYPE="submit" VALUE="Upload"> 23. </FORM> 24. 25. </BODY> 26. </HTML> 上传版本1: Code: 1. <?php 2. if (is_uploaded_file($_FILES['upfile']['tmp_name']))//看是否上传成功 3. { 4. $upfile=$_FILES["upfile"]; 5. $name = $upfile["name"]; 6. $type = $upfile["type"]; 7. $size = $upfile["size"]; 8. $tmp_name = $upfile["tmp_name"]; 9. $error = $upfile["error"]; 10. 11. switch ($type) 12. { 13. case 'image/pjpeg' : $ok=1; 14. break; 15. case 'image/jpeg' : $ok=1; 16. break; 17. case 'image/gif' : $ok=1; 18. break; 19. case 'image/png' : $ok=1; 20. break; 21. } 22. if($ok && $error=='0') 23. { 24. move_uploaded_file($tmp_name,'up/'.$name); 25. echo "上传成功"; 26. } 27. } 28. 29. ?> 30. <form action="" enctype="multipart/form-data" method="post" name="upform"> 31. 上传文件: 32. <input name="upfile" type="file"> 33. <input type="submit" value="上传"> 34. </form> 上传代码版本2: <?php /****************************************************************************** 参数说明: $max_file_size : 上传文件大小限制, 单位BYTE $destination_folder : 上传文件路径 $watermark : 是否附加水印(1为加水印,其他为不加水印); 使用说明: 1. 将PHP.INI文件里面的"extension=php_gd2.dll"一行前面的;号去掉,因为我们要用到GD库; 2. 将extension_dir =改为你的php_gd2.dll所在目录; ******************************************************************************/ //上传文件类型列表 $uptypes=array( 'image/jpg', 'image/jpeg', 'image/png', 'image/pjpeg', 'image/gif', 'image/bmp', 'image/x-png' ); $max_file_size=2000000; //上传文件大小限制, 单位BYTE $destination_folder="uploadimg/"; //上传文件路径 $watermark=1; //是否附加水印(1为加水印,其他为不加水印); $watertype=1; //水印类型(1为文字,2为图片) $waterposition=1; //水印位置(1为左下角,2为右下角,3为左上角,4为右上角,5为居中); $waterstring="http://www.xplore.cn/"; //水印字符串 $waterimg="xplore.gif"; //水印图片 $imgpreview=1; //是否生成预览图(1为生成,其他为不生成); $imgpreviewsize=1/2; //缩略图比例 ?> <html> <head> <title>php上传</title> <style type="text/css"> <!-- body { font-size: 9pt; } input { background-color: #66CCFF; border: 1px inset #CCCCCC; } --> </style> </head> <body> <form enctype="multipart/form-data" method="post" name="upform"> 上传文件: <input name="upfile" type="file"> <input type="submit" value="上传"> 允许上传的文件类型为:<?=implode(', ',$uptypes)?> </form> <?php if ($_SERVER['REQUEST_METHOD'] == 'POST') { if (!is_uploaded_file($_FILES["upfile"][tmp_name])) //是否存在文件 { echo "图片不存在!"; exit; } $file = $_FILES["upfile"]; if($max_file_size < $file["size"]) //检查文件大小 { echo "文件太大!"; exit; } if(!in_array($file["type"], $uptypes)) //检查文件类型 { echo "文件类型不符!".$file["type"]; exit; } if(!file_exists($destination_folder)) { mkdir($destination_folder); } $filename=$file["tmp_name"]; $image_size = getimagesize($filename); $pinfo=pathinfo($file["name"]); $ftype=$pinfo['extension']; $destination = $destination_folder.time().".".$ftype; if (file_exists($destination) && $overwrite != true) { echo "同名文件已经存在了"; exit; } if(!move_uploaded_file ($filename, $destination)) { echo "移动文件出错"; exit; } $pinfo=pathinfo($destination); $fname=$pinfo[basename]; echo " <font color=red>已经成功上传 文件名: <font color=blue>".$destination_folder.$fname." "; echo " 宽度:".$image_size[0]; echo " 长度:".$image_size[1]; echo " 大小:".$file["size"]." bytes"; if($watermark==1) { $iinfo=getimagesize($destination,$iinfo); $nimage=imagecreatetruecolor($image_size[0],$image_size[1]); $white=imagecolorallocate($nimage,255,255,255); $black=imagecolorallocate($nimage,0,0,0); $red=imagecolorallocate($nimage,255,0,0); imagefill($nimage,0,0,$white); switch ($iinfo[2]) { case 1: $simage =imagecreatefromgif($destination); break; case 2: $simage =imagecreatefromjpeg($destination); break; case 3: $simage =imagecreatefrompng($destination); break; case 6: $simage =imagecreatefromwbmp($destination); break; default: die("不支持的文件类型"); exit; } imagecopy($nimage,$simage,0,0,0,0,$image_size[0],$image_size[1]); imagefilledrectangle($nimage,1,$image_size[1]-15,80,$image_size[1],$white); switch($watertype) { case 1: //加水印字符串 imagestring($nimage,2,3,$image_size[1]-15,$waterstring,$black); break; case 2: //加水印图片 $simage1 =imagecreatefromgif("xplore.gif"); imagecopy($nimage,$simage1,0,0,0,0,85,15); imagedestroy($simage1); break; } switch ($iinfo[2]) { case 1: //imagegif($nimage, $destination); imagejpeg($nimage, $destination); break; case 2: imagejpeg($nimage, $destination); break; case 3: imagepng($nimage, $destination); break; case 6: imagewbmp($nimage, $destination); //imagejpeg($nimage, $destination); break; } //覆盖原上传文件 imagedestroy($nimage); imagedestroy($simage); } if($imgpreview==1) { echo " 图片预览: "; echo "<img src=\"".$destination."\" width=".($image_size[0]*$imgpreviewsize)." height=".($image_size[1]*$imgpreviewsize); echo " alt=\"图片预览:\r文件名:".$destination."\r上传时间:\">"; } } ?> </body> |
相关阅读 更多 +