Dedecmsv5.7整合ueditor 图片上传添加水印

Dedecmsv5.7整合ueditor 图片上传添加水印,第1张

概述最近的项目是做dedecmsv5.7的二次开发,被要求上传的图片要加水印,百度ueditor编辑器不支持自动加水印,所以,找了很多资料整合记录一下,具体效果图

最近的项目是做Dedecmsv5.7的二次开发,被要求上传的图片要加水印,百度ueditor编辑器不支持自动加水印,所以,找了很多资料整合记录一下,具体效果图

这里不仔细写Dedecmsv5.7 整合ueditor编辑器了

1、打开ueditor目录下的PHP目录下的config.Json配置文件

"iswatermark": false,/*图片加水印,默认不加水印*/

2、打开ueditor下的PHP文件夹里的action_upload.PHP,

(1)找到

case 'uploadimage':$config = array("pathFormat" => $CONfig['imagePathFormat'],"maxSize" => $CONfig['imageMaxSize'],"allowfiles" => $CONfig['imageAllowfiles']        );$fIEldname = $CONfig['imageFIEldname'];break;

在break;之前加入

/*判断session 是因为在前端是否添加水印,  如果添加了水印,则设置session['iswatermark'] = 1,否则=0*/if(isset($_SESSION['iswatermark'])){$watermark = $_SESSION['iswatermark'];        }else{$watermark = $CONfig['iswatermark'];        }

(2)找到:

/* 生成上传实例对象并完成上传 */$up = new Uploader($fIEldname,$config,$base64);

改为:

/* 生成上传实例对象并完成上传 */$up = new Uploader($fIEldname,$base64,$watermark);

3、打开ueditor下的PHP文件夹里的Uploader.class.PHP

(1)在构造函数__construct上面添加

private $water; //是否添加水印(属性)

(2)把构造函数改成

/**     * 构造函数     * @param string $fileFIEld 表单名称     * @param array $config 配置项     * @param bool $base64 是否解析base64编码,可省略。若开启,则$fileFIEld代表的是base64编码的字符串表单名     */public function __construct($fileFIEld,$type = "upload",$watermark = false)

(3)在构造函数里面加入

$this->water = $watermark;

(4)在upfile方法里加入

//移动文件if (!(move_uploaded_file($file["tmp_name"],$this->filePath) && file_exists($this->filePath))) { //移动失败$this->stateInfo = $this->getStateInfo("ERROR_file_MOVE");        } else { //移动成功if($this->water){$this->watermark($this->filePath,$this->filePath);            }$this->stateInfo = $this->stateMap[0];        }

注:上面加粗的加入的代码。如果把这段代码放在移动文件上面,下面加水印的话找不见源图片

(5)在这个类文件里添加以下方法,实现图片添加水印

/**     * 图片加水印     * $source  string  图片资源     * $target  string  添加水印后的名字     * $w_pos   int     水印位置安排(1-10)【1:左头顶;2:中间头顶;3:右头顶...值空:随机位置】     * $w_img   string  水印图片路径     * $w_text  string  显示的文字     * $w_Font  int     字体大小     * $w_color string  字体颜色     *     */public function watermark($source,$target = '',$w_pos = 9,$w_img = '',$w_text = '56nev.com',$w_Font = 10,$w_color = '#CC0000')    {$this->w_img = '../../../data/mark/mark.png';//水印图片$this->w_pos = 9 ;$this->w_minwIDth = 100;//最少宽度$this->w_minheight = 20;//最少高度$this->w_quality = 100;//图像质量$this->w_pct = 85;//透明度$w_pos = $w_pos ? $w_pos : $this->w_pos;$w_img = $w_img ? $w_img : $this->w_img;if(!$this->check($source)) return false;if(!$target) $target = $source;$source_info = getimagesize($source);//图片信息$source_w  = $source_info[0];//图片宽度$source_h  = $source_info[1];//图片高度if($source_w < $this->w_minwIDth || $source_h < $this->w_minheight) return false;switch($source_info[2]) { //图片类型case 1 : //GIF格式$source_img = imagecreatefromgif($source);break;case 2 : //JPG格式$source_img = imagecreatefromjpeg($source);break;case 3 : //PNG格式$source_img = imagecreatefrompng($source);//imageAlphablending($source_img,false); //关闭混色模式imagesaveAlpha($source_img,true); //设置标记以在保存 PNG 图像时保存完整的 Alpha 通道信息(与单一透明色相反)break;default :return false;        }if(!empty($w_img) && file_exists($w_img)) { //水印图片有效$ifwaterimage = 1; //标记$water_info  = getimagesize($w_img);$wIDth    = $water_info[0];$height    = $water_info[1];switch($water_info[2]) {case 1 :$water_img = imagecreatefromgif($w_img);break;case 2 :$water_img = imagecreatefromjpeg($w_img);break;case 3 :$water_img = imagecreatefrompng($w_img);                    imageAlphablending($water_img,false);                    imagesaveAlpha($water_img,true);break;default :return;            }        }else{$ifwaterimage = 0;$temp = imagettfbBox(ceil($w_Font*2.5),'../../texb.ttf',$w_text); //imagettfbBox返回一个含有 8 个单元的数组表示了文本外框的四个角$wIDth = $temp[2] - $temp[6];$height = $temp[3] - $temp[7];unset($temp);        }switch($w_pos) {case 1:$wx = 5;$wy = 5;break;case 2:$wx = ($source_w - $wIDth) / 2;$wy = 0;break;case 3:$wx = $source_w - $wIDth;$wy = 0;break;case 4:$wx = 0;$wy = ($source_h - $height) / 2;break;case 5:$wx = ($source_w - $wIDth) / 2;$wy = ($source_h - $height) / 2;break;case 6:$wx = $source_w - $wIDth;$wy = ($source_h - $height) / 2;break;case 7:$wx = 0;$wy = $source_h - $height;break;case 8:$wx = ($source_w - $wIDth) / 2;$wy = $source_h - $height;break;case 9:$wx = $source_w - ($wIDth+5);$wy = $source_h - ($height+5);break;case 10:$wx = rand(0,($source_w - $wIDth));$wy = rand(0,($source_h - $height));break;default:$wx = rand(0,($source_h - $height));break;        }/*           dst_im  目标图像           src_im  被拷贝的源图像           dst_x   目标图像开始 x 坐标           dst_y   目标图像开始 y 坐标,x,y同为 0 则从左上角开始           src_x   拷贝图像开始 x 坐标           src_y   拷贝图像开始 y 坐标,x,y同为 0 则从左上角开始拷贝           src_w   (从 src_x 开始)拷贝的宽度           src_h   (从 src_y 开始)拷贝的高度           pct 图像合并程度,取值 0-100 ,当 pct=0 时,实际上什么也没做,反之完全合并。       */if($ifwaterimage) {if($water_info[2] == 3) {                imagecopy($source_img,$water_img,$wx,$wy,$wIDth,$height);            }else{                imagecopymerge($source_img,$height,$this->w_pct);            }        }else{if(!empty($w_color) && (strlen($w_color)==7)) {$r = hexdec(substr($w_color,1,2));$g = hexdec(substr($w_color,3,2));$b = hexdec(substr($w_color,5));            }else{return;            }            imagestring($source_img,$w_Font,$w_text,imagecolorallocate($source_img,$r,$g,$b));        }switch($source_info[2]) {case 1 :                imagegif($source_img,$target);//GIF 格式将图像输出到浏览器或文件(欲输出的图像资源,指定输出图像的文件名)break;case 2 :                imagejpeg($source_img,$target,$this->w_quality);break;case 3 :                imagepng($source_img,$target);break;default :return;        }if(isset($water_info)){unset($water_info);        }if(isset($water_img)) {            imagedestroy($water_img);        }unset($source_info);        imagedestroy($source_img);return true;    }public function check($image){return extension_loaded('gd') && preg_match("/\.(jpg|jpeg|gif|png)/i",$image,$m) && file_exists($image) && function_exists('imagecreatefrom'.($m[1] == 'jpg' ? 'jpeg' : $m[1]));    }

到这一步,已经基本完成添加水印的处理了

4、解决的是前台选择“是否添加水印”的交互

思路:我是用Js添加了radio 添加水印,不添加水印。通过AJAX 设置session。添加水印,则设置session['iswatermark'] = 1,不添加则=0。就是第2、步,判断session那步

(1)setwater@R_849_5020@文件

window.onload = function(){var toolbar = $('body[topmargin=8] form #edui2');var HTML = '原创图片加水印(在上传之前选中)' +        '不添加水印';    toolbar.append(HTML);    $('body[topmargin=8] form #edui2 .changec').click(function () {var status = $(this).val();        $.getJsON('/include/ueditor/PHP/controller.PHP',{"action":"setwatermark","watermark":status},function(data){       })    })}

这个里面的getJson的url可以是任何PHP文件,目的是为了设置session,因为我想把相关的文件放在一起,所以写在了controller.PHP里面

可以根据具体的项目去找到对应的document元素然后往里面append。把这个Js文件引入的页面里就可以了。

(2)找到ueditor下的PHP文件夹里的controller.PHP,

现在这个PHP文件的开头添加:

session_start();

如果开启 session没有写在开头的话,一刷新session就没了

在switch ($action) {}里面加入

/*设置是否加水印*/case 'setwatermark':$watermark = (isset($_GET['watermark']) && $_GET['watermark'])?$_GET['watermark']:0;if($watermark==1){$_SESSION['iswatermark'] = 1;        }elseif ($watermark==0){$_SESSION['iswatermark'] = 0;        }else{if(!isset($_SESSION['iswatermark'])){$_SESSION['iswatermark'] = 0;            }        }break;

到此,ueditor编辑器添加水印前后台交互就完成了。可能写的有点乱 :(

前后台交互的方法,本人愚笨,用了session的笨办法,如果还有更好的方法,大家可以留言交流!

总结

以上是内存溢出为你收集整理的Dedecmsv5.7整合ueditor 图片上传添加水印全部内容,希望文章能够帮你解决Dedecmsv5.7整合ueditor 图片上传添加水印所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://outofmemory.cn/zz/1066558.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-26
下一篇2022-06-04

随机推荐

  • 2021法考《民事诉讼法》上诉案件的审理疑难解答

    以下内容为大家在学习《民事诉讼法》上诉案件的审理中疑问比较多的问题,此处列举该项问题和答案,大家可以学习和检测自己是否对此处的问题也有同样的疑问,从而能够查漏补缺。1. 问题:二审当事人可以撤诉吗?【

    2022-12-10
    000
  • 中小学二级教师几年后可以评一级

    二级教师定级后,需要任职二级教师4年后才能评选一级教师。需要的条件是从教以来有两年班主任等管理工作,继续教育学习合格等条件;如果是硕士研究生学历,二级定级以后履职满两年就可以了申报条件 :申报者应拥护

  • 幼儿教师资格证申请认定需要什么材料

    1、面试合格证。幼儿教师是需要有幼儿教师资格证的,在面试成绩出来之后,如果成绩合格通过了的话,就可以下载并打印面积成绩合格后的证明了。2、普通话水平测试等级证书。大家在进行幼儿教师资格证认证的时候,就

    2022-12-10
    000
  • 朗诵的技巧

    朗诵是一种传情的艺术。朗诵者要很好地传情,引起听众共鸣,首先要注意材料的选择。选择材料时,首先要注意选择那些语言具有形象性而且适于上口的文章。因为形象感受是朗诵中一个很重要的环节;干瘪枯燥的书面语言对

  • 演讲的方法与技巧

    演讲的方法技巧:1.演讲时候仪容一定要到位,2.注意面部表情的到位,3.演讲时的姿式有讲究,4.要有一定的手势,5.在演讲时注意位置的移动,6.一定要与场上观众有目光的交流。演讲时候仪容一定要到位无论

    2022-12-10
    000
  • 零基础学钢琴

    零基础学钢琴首先需要学习弹奏基本指法,了解弹奏基本类型,如键盘独奏,键盘伴奏等等,然后要学习掌握和弦,循序渐进,从最简单的伴奏方式开始练起。零基础学钢琴1、弹奏基本指法少动为妙。以右手为例,拇指弹最低

    2022-12-10
    000
  • 电工快速拿证

    从事电工操作工作的你应该都知道,必须有电工操作证和电工进网作业许可证双证上岗的,怎么样快速拿电工证?电工操作证:也称电工上岗证,电工特种作业操作证,即特种作业人员操作证(电工),从事电气设备安装、维修

    2022-12-10
    000
  • 学护理专业可以当育婴师吗

    《标准》对于育婴人员的技能要求相当高:注重科学性,孩子在什么时候进行什么样的训练,大动作、精细动作等的训练要达到什么样的程度,根据每个孩子的情况,都会有不同标准;要对不同的孩子,从吃、喝、玩、睡、语言

    2022-12-10
    000
  • 二级建造师考试题目和答案:建设工程质量法律制度

    1.按照《标准化法》的规定,( )是正确的。A. 国家标准就是强制性标准B. 行业标准、地方标准一律为推荐性标准C. 保障人体健康、人身财产安全的标准,可以制定强制性标准D. 国家标准应当免费向社会公

    2022-12-10
    000

发表评论

登录后才能评论

评论列表(0条)

    保存