function upload($uploadfile,$watermark=1,$watertype=1,$content){
foreach($uploadfile['name'] as $key=>$name) { //多文件上传函数
uploadall($uploadfile,$key,$watermark,$watertype,$content);
}
}
function uploadall($uploadfile,$i,$watermark,$watertype,$content) {
$watermark=$watermark; //是否附加水印(1为加水印,其他为不加水印);
$watertype=$watertype; //水印类型(1为文字,2为图片)
$watercontent=$content; //水印的内容
if(empty($uploadfile['name'][$i])) {
die("未选择文件上传");
}
if($uploadfile['error'][$i] == 2) { //验证html判断结果
die("上传的文件太大了");
}
$allow_filemaxsize = 2048000; // 2m
$filesize = $uploadfile['size'][$i];
if($filesize > $allow_filemaxsize) {
die("上传的文件太大了");
}
$allow_filetypes = array("jpeg", "gif", "png","jpg","pjpeg");//允许上传的文件统一资源类型 mimetype
$allow = false; //默认都不允许
$mimetype = $uploadfile['type'][$i]; //上传文件的mime文件类型
foreach($allow_filetypes as $t) {
if(strpos($mimetype, $t) !== false) {
$allow = true; //找到了符合上传条件的文件类型
break;
}
}
if($allow == false) {
die("上传的文件类型不被允许");
}
$result = is_uploaded_file($uploadfile['tmp_name'][$i]); //判断是否为上传动作产生的
if(!$result) {
die("上传的文件有误");
}
$uploaddir = "img/"; //上传文件保存目录
if(!file_exists($uploaddir)) mkdir($uploaddir, 0777, true);//若上传保存目录不存在,则递归创建
/**重命名文件**/
$filetype = explode(".", $uploadfile['name'][$i]);
$filetype = array_pop($filetype);
$uploadfilename = time().".".$filetype;
$_session['filename'] = $uploadfilename;
//end
$result = move_uploaded_file($uploadfile['tmp_name'][$i], $uploaddir.$uploadfilename);
if($result) {
echo "文件上传成功";
}else{
switch($uploadfile['error'][$i]) {
case 1:return "上传的文件超出了php.ini中设定的最大值";break;
case 2:return "上传的文件超出了html中设定的最大值";break;
case 3:return "文件只有部分被上传";break;
case 4;return "没有文件被上传";break;
default:die("文件上传失败");
}
}
if($watermark==1) {
$iinfo=getimagesize($uploaddir.$uploadfilename); //获取图片的相关信息,得到数组
$nimage=imagecreatetruecolor($iinfo[0],$iinfo[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($uploaddir.$uploadfilename);
break;
case 2:
$simage =imagecreatefromjpeg($uploaddir.$uploadfilename);
break;
case 3:
$simage =imagecreatefrompng($uploaddir.$uploadfilename);
break;
case 6:
$simage =imagecreatefromwbmp($uploaddir.$uploadfilename);
break;
default:
die("不支持的文件类型");
exit;
}
imagecopy($nimage,$simage,0,0,0,0,$iinfo['0'],$iinfo['1']);
switch($watertype) {
case 1: //加水印字符串
imagestring($nimage,5,$iinfo['0']/2-50,$iinfo['1']-30,$watercontent,$black);
break;
case 2: //加水印图片
$simage1 =imagecreatefromgif($watercontent);
$size = getimagesize($watercontent);
imagecopy($nimage,$simage1,$iinfo['0']/2+50,$iinfo['1']-100,0,0,$size[0],$size[1]);
imagedestroy($simage1);
break;
}
switch ($iinfo[2]) {
case 1:
imagejpeg($nimage, $uploaddir.$uploadfilename); //将图像$nimage以$destination文件名创建一个jpeg的格式文件
break;
case 2:
imagejpeg($nimage, $uploaddir.$uploadfilename);
break;
case 3:
imagepng($nimage, $uploaddir.$uploadfilename);
break;
case 6:
imagewbmp($nimage, $uploaddir.$uploadfilename);
break;
}
imagedestroy($nimage); //覆盖原上传文件
imagedestroy($simage);
}
}
if(@$_get['act'] == "insert") { //未作参数校验
//该函数的四个参数分别是:上传控件的name值;是否加水印(1为加,其他数字为不佳);
//水印的类型(1为字符串,2为图片);水印的内容,字符串时写数据,图片时写图片的地址;
$picture = upload($_files['picture'],1,2,"img/watermark.gif");//上传文件,并返回上传后的文件路径名
}
?>
|