<?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.php100.com/"; //水印字符串
$waterimg="xplore.gif"; //水印图片
$imgpreview=1; //是否生成预览图(1为生成,其他为不生成);
$imgpreviewsize=1/2; //缩略图比例
?>
<form enctype="multipart/form-data" method="post" name="upform"><!--注: 要确保文件上传表单的属性是 enctype="multipart/form-data",否则文件上传不了。-->
上传文件:
<input name="upfile" type="file">
<input type="submit" value="上传"><br>
允许上传的文件类型为:<?=implode(', ',$uptypes)?><!-- 将数组变成字符串。各数组间用‘,’分开. -->
</form>
<?php
if ($_SERVER['REQUEST_METHOD'] == 'POST')//访问页面时的请求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。 注: 如果请求的方式是 HEAD,PHP 脚本将在送出头信息后中止(这意味着在产生任何输出后,不再有输出缓冲)。
{
if (!is_uploaded_file($_FILES["upfile"][tmp_name]))//语法:bool is_uploaded_file ( string filename ) 判断文件是否是通过 HTTP POST 上传的。
/*
* 我们假设文件上传字段的名称如上例所示,为 userfile。名称可随意命名。
$_FILES['userfile']['name']
客户端机器文件的原名称。
$_FILES['userfile']['type']
文件的 MIME 类型,如果浏览器提供此信息的话。一个例子是“image/gif”。不过此 MIME 类型在 PHP 端并不检查,因此不要想当然认为有这个值。
$_FILES['userfile']['size']
已上传文件的大小,单位为字节。
$_FILES['userfile']['tmp_name']
文件被上传后在服务端储存的临时文件名。
$_FILES['userfile']['error']
和该文件上传相关的错误代码。错误代码值有:
其值为 0,没有错误发生,文件上传成功。
其值为 1,上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
其值为 2,上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
其值为 3,文件只有部分被上传。
其值为 4,没有文件被上传。
其值为 6,找不到临时文件夹。PHP 4.3.10 和 PHP 5.0.3 引进。
其值为 7,文件写入失败。PHP 5.1.0 引进。
*/
//是否存在文件
{
echo "图片不存在!";
exit;
}
$file = $_FILES["upfile"];//$file变成一个数组.
if($max_file_size < $file["size"])
//检查文件大小
{
echo "文件太大!";
exit;
}
if(!in_array($file["type"], $uptypes))//in_array -- 检查数组中是否存在某个值
//检查文件类型
//语法:bool in_array ( mixed needle, array haystack [, bool strict] )
//在 haystack 中搜索 needle,如果找到则返回 TRUE,否则返回 FALSE。
//如果第三个参数 strict 的值为 TRUE 则 in_array() 函数还会检查 needle 的类型是否和 haystack 中的相同。
//注: 如果 needle 是字符串,则比较是区分大小写的。
{
echo "文件类型不符:".$file["type"];
exit;
}
if(!file_exists($destination_folder))//file_exists -- 检查文件或目录是否存在 语法:bool file_exists ( string filename )如果由 filename 指定的文件或目录存在则返回 TRUE,否则返回 FALSE。
{
mkdir($destination_folder);//mkdir -- 新建目录 语法:bool mkdir ( string pathname [, int mode] )如果成功则返回 TRUE,失败则返回 FALSE。注: Mode 在 Windows 下被忽略。默认的 mode 是 0777,意味着最大可能的访问权。
}
$filename=$file["tmp_name"];//文件被上传后在服务端储存的临时文件名。
$image_size = getimagesize($filename);//getimagesize -- 取得图像大小
//返回一个具有四个单元的数组。
//索引 0 包含图像宽度的像素值。
//索引 1 包含图像高度的像素值。
//索引 2 是图像类型的标记:
//1 = GIF,2 = JPG,3 = PNG,4 = SWF,5 = PSD,6 = BMP,7 = TIFF(intel byte order),8 = TIFF(motorola byte order),9 = JPC,10 = JP2,11 = JPX,12 = JB2,13 = SWC,14 = IFF,15 = WBMP,16 = XBM。
//索引 3 是文本字符串,内容为“height="yyy" width="xxx"”,可直接用于 IMG 标记。
$pinfo=pathinfo($file["name"]);//语法:array pathinfo ( string path [, int options] ) -- 返回文件路径的信息
//pathinfo() 返回一个联合数组包含有 path 的信息。包括以下的数组单元:dirname,basename 和 extension。
/* 例子:
* <?php
$path_parts = pathinfo("/www/htdocs/index.html");
echo $path_parts["dirname"] . "\n";
echo $path_parts["basename"] . "\n";
echo $path_parts["extension"] . "\n";
?>
上例将输出:
/www/htdocs
index.html
html
*/
$ftype=$pinfo['extension'];
$destination = $destination_folder.time().".".$ftype;//函数:time() 返回当前的 Unix 时间戳
if (file_exists($destination) && $overwrite != true)//&& 与。|| 或。$overwrite 允许覆盖远程服务器上已存在的文件。仅适用于写入模式(上传)。默认值:FALSE(禁用)
{
echo "同名文件已经存在了";
exit;
}
if(!move_uploaded_file ($filename, $destination))//move_uploaded_file -- 将上传的文件移动到新位置
//bool move_uploaded_file ( string filename, string destination )
//本函数检查并确保由 filename 指定的文件是合法的上传文件(即通过 PHP 的 HTTP POST 上传机制所上传的)。如果文件合法,则将其移动为由 destination 指定的文件。
//如果 filename 不是合法的上传文件,不会出现任何操作,move_uploaded_file() 将返回 FALSE。
{
echo "移动文件出错";
exit;
}
$pinfo=pathinfo($destination);
$fname=$pinfo[basename];
echo " <font color=red>已经成功上传</font><br>文件名: <font color=blue>".$destination_folder.$fname."</font><br>";
echo " 宽度:".$image_size[0];//索引 0 包含图像宽度的像素值。
echo " 长度:".$image_size[1];//索引 1 包含图像高度的像素值。
echo "<br> 大小:".$file["size"]." bytes";//bytes字节
//图片水印处理开始:
if($watermark==1)
{
$iinfo=getimagesize($destination,$iinfo);//可否写成:$iinfo=getimagesize($destination);?
$nimage=imagecreatetruecolor($image_size[0],$image_size[1]);
//语法:resource imagecreatetruecolor ( int x_size, int y_size )-- 新建一个真彩色图像
//imagecreatetruecolor() 返回一个图像标识符,代表了一幅大小为 x_size 和 y_size 的黑色图像。
$white=imagecolorallocate($nimage,255,255,255);
//语法:int imagecolorallocate ( resource image, int red, int green, int blue )
//imagecolorallocate -- 为一幅图像分配颜色
//imagecolorallocate() 返回一个标识符,代表了由给定的 RGB 成分组成的颜色。
$black=imagecolorallocate($nimage,0,0,0);
$red=imagecolorallocate($nimage,255,0,0);
imagefill($nimage,0,0,$white);
//语法:bool imagefill ( resource image, int x, int y, int color )
//imagefill -- 区域填充
//imagefill() 在 image 图像的坐标 x,y(图像左上角为 0, 0)处用 color 颜色执行区域填充(即与 x, y 点颜色相同且相邻的点都会被填充)。
switch ($iinfo[2])
{
case 1: //1 = GIF
$simage =imagecreatefromgif($destination); //magecreatefromgif -- 从 GIF 文件或 URL 新建一图像
//imagecreatefromgif() 返回一图像标识符,代表了从给定的文件名取得的图像。
break;
case 2: //2 = JPG
$simage =imagecreatefromjpeg($destination); //imagecreatefromjpeg -- 从 JPEG 文件或 URL 新建一图像
//imagecreatefromjpeg() 返回一图像标识符,代表了从给定的文件名取得的图像。
break;
case 3: //3 = PNG
$simage =imagecreatefrompng($destination); //imagecreatefrompng -- 从 PNG 文件或 URL 新建一图像
//imagecreatefrompng() 返回一图像标识符,代表了从给定的文件名取得的图像。
break;
case 6: //6 = BMP 是case 15: //15 = WBMP 好像才正确吧?
$simage =imagecreatefromwbmp($destination); //imagecreatefromwbmp -- 从 WBMP 文件或 URL 新建一图像
//imagecreatefromwbmp() 返回一图像标识符,代表了从给定的文件名取得的图像。
break;
default:
die("不支持的文件类型");
exit;
}
imagecopy($nimage,$simage,0,0,0,0,$image_size[0],$image_size[1]);
//语法:bool imagecopy ( resource dst_im, resource src_im, int dst_x, int dst_y, int src_x, int src_y, int src_w, int src_h )
//将 src_im 图像中坐标从 src_x,src_y 开始,宽度为 src_w,高度为 src_h 的一部分拷贝到 dst_im 图像中坐标为 dst_x 和 dst_y 的位置上。
imagefilledrectangle($nimage,1,$image_size[1]-15,80,$image_size[1],$white);
//语法:bool imagefilledrectangle ( resource image, int x1, int y1, int x2, int y2, int color )
//imagefilledrectangle -- 画一矩形并填充
//imagefilledrectangle() 在 image 图像中画一个用 color 颜色填充了的矩形,其左上角坐标为 x1,y1,右下角坐标为 x2,y2。(0, 0) 是图像的最左上角。
switch($watertype)
{
case 1: //加水印字符串
imagestring($nimage,2,3,$image_size[1]-15,$waterstring,$black);
//语法:bool imagestring ( resource image, int font, int x, int y, string s, int col )
//imagestring -- 水平地画一行字符串
//imagestring() 用 col 颜色将字符串 s 画到 image 所代表的图像的 x,y 坐标处(这是字符串左上角坐标,整幅图像的左上角为 0,0)。
//如果 font 是 1,2,3,4 或 5,则使用内置字体。
break;
case 2: //加水印图片
$simage1 =imagecreatefromgif("xplore.gif");
//magecreatefromgif -- 从 GIF 文件或 URL 新建一图像
imagecopy($nimage,$simage1,0,0,0,0,85,15);
imagedestroy($simage1);
//imagedestroy -- 销毁一图像
//语法:bool imagedestroy ( resource image )
//imagedestroy() 释放与 image 关联的内存。
break;
}
//以下开始覆盖原上传文件
switch ($iinfo[2])
{
case 1:
//imagegif($nimage, $destination);
imagejpeg($nimage, $destination);
//imagegif -- 以 GIF 格式将图像输出到浏览器或文件
//imagejpeg -- 以 JPEG 格式将图像输出到浏览器或文件
break;
case 2:
imagejpeg($nimage, $destination);
break;
case 3:
imagepng($nimage, $destination);
//imagepng -- 以 PNG 格式将图像输出到浏览器或文件
break;
case 6:
imagewbmp($nimage, $destination);//imagewbmp -- 以 WBMP 格式将图像输出到浏览器或文件
//imagejpeg($nimage, $destination);
break;
}
imagedestroy($nimage);////imagedestroy -- 销毁一图像
imagedestroy($simage);
}
if($imgpreview==1)
{
echo "<br>图片预览:<br>";
echo "<img src=\"".$destination."\" width=".($image_size[0]*$imgpreviewsize)." height=".($image_size[1]*$imgpreviewsize);
echo " alt=\"图片预览:\r文件名:".$destination."\r上传时间:\">";
}
}
?>
摘自:http://hi.baidu.com/vipbressanon/blog/item/adf4514e63df4df2d72afc8e.html
没有评论:
发表评论