首頁 > 軟體

PHP利用ueditor實現上傳圖片新增水印

2022-07-05 18:01:37

部落格在上傳圖片的時候,我希望能打上我部落格連結的水印,掘金,csdn都是這麼幹的,這事我得學習。

平時的圖片上傳還好說,在文章編輯的時候,使用ueditor上傳圖片加水印需要修改ueditor部分PHP的原始碼,我這裡大概記錄一下。

首先開啟php資料夾下的Uploader.class.php

找到private function upFile(),這是上傳檔案的主處理方法,

找到122行: $this->stateInfo = $this->stateMap[0];

在這個下面加入:$this->imageWaterMark($this->filePath,9,'logo.png');

 imageWaterMark是自定義的函數,

在下面會說到,$this->filePath 這是上傳圖片的路徑,9 表示的是水印的位置,在右下角,logo.png這個就是你要新增的水印圖片了,這個在同一目錄下/php/,如果要放到其它路徑請用相對路徑。

下面這個就是自定義函數了,新增到Uploader 類中 所有的引數都已在函數註釋中說明,呼叫的時候需要注意一下

/*
    * 功能:PHP圖片水印 (水印支援圖片或文字)
    * 引數:
    
    *$groundImage 背景圖片,即需要加水印的圖片,暫只支援GIF,JPG,PNG格式;
    
    *$waterPos水印位置,有10種狀態,0為隨機位置;
    
    *1為頂端居左,2為頂端居中,3為頂端居右;
    *4為中部居左,5為中部居中,6為中部居右;
    *7為底端居左,8為底端居中,9為底端居右;
    
    *$waterImage圖片水印,即作為水印的圖片,暫只支援GIF,JPG,PNG格式;
    
    *$waterText文字水印,即把文字作為為水印,支援ASCII碼,不支援中文;
    
    *$textFont文字大小,值為1、2、3、4或5,預設為5;
    
    *$textColor文字顏色,值為十六進位制顏色值,預設為#FF0000(紅色);
    
    * 注意:Support GD 2.0,Support FreeType、GIF Read、GIF Create、JPG 、PNG
    
    *$waterImage 和 $waterText 最好不要同時使用,選其中之一即可,優先使用 $waterImage。
    
    *當$waterImage有效時,引數$waterString、$stringFont、$stringColor均不生效。
    
    *加水印後的圖片的檔名和 $groundImage 一樣。
    */
    private function imageWaterMark($groundImage,$waterPos=0,$waterImage="",$waterText="",$textFont=5,$textColor="#FF0000")
    {
        $isWaterImage = FALSE;
        $formatMsg = "暫不支援該檔案格式,請用圖片處理軟體將圖片轉換為GIF、JPG、PNG格式。";
        //讀取水印檔案
        if(!empty($waterImage) && file_exists($waterImage))
        {
            $isWaterImage = TRUE;
            $water_info = getimagesize($waterImage);
            $water_w = $water_info[0];//取得水印圖片的寬
            $water_h = $water_info[1];//取得水印圖片的高 
            switch($water_info[2])//取得水印圖片的格式
            {
                case 1:$water_im = imagecreatefromgif($waterImage);break;
                case 2:$water_im = imagecreatefromjpeg($waterImage);break;
                case 3:$water_im = imagecreatefrompng($waterImage);break;
                default:die($formatMsg);
            }
        }
        //讀取背景圖片
        if(!empty($groundImage) && file_exists($groundImage))
        {
            $ground_info = getimagesize($groundImage);
            $ground_w = $ground_info[0];//取得背景圖片的寬
            $ground_h = $ground_info[1];//取得背景圖片的高
            switch($ground_info[2])//取得背景圖片的格式
            {
                case 1:$ground_im = imagecreatefromgif($groundImage);break;
                case 2:$ground_im = imagecreatefromjpeg($groundImage);break;
                case 3:$ground_im = imagecreatefrompng($groundImage);break;
                default:die($formatMsg);
            }
        }
        else
        {
            die("需要加水印的圖片不存在!");
        }
        //水印位置
        if($isWaterImage)//圖片水印
        {
            $w = $water_w;
            $h = $water_h;
            $label = "圖片的";
        }
        else//文字水印
        {
            $temp = imagettfbbox(ceil($textFont*5),0,"./cour.ttf",$waterText);//取得使用 TrueType 字型的文字的範圍
            $w = $temp[2] - $temp[6];
            $h = $temp[3] - $temp[7];
            unset($temp);
            $label = "文字區域";
        }
        if( ($ground_w<$w) || ($ground_h<$h) )
        {
            echo "需要加水印的圖片的長度或寬度比水印".$label."還小,無法生成水印!";
            return;
        }
        switch($waterPos)
        {
            case 0://隨機
                $posX = rand(0,($ground_w - $w));
                $posY = rand(0,($ground_h - $h));
                break;
            case 1://1為頂端居左
                $posX = 0;
                $posY = 0;
                break;
            case 2://2為頂端居中
                $posX = ($ground_w - $w) / 2;
                $posY = 0;
                break;
            case 3://3為頂端居右
                $posX = $ground_w - $w;
                $posY = 0;
                break;
            case 4://4為中部居左
                $posX = 0;
                $posY = ($ground_h - $h) / 2;
                break;
            case 5://5為中部居中
                $posX = ($ground_w - $w) / 2;
                $posY = ($ground_h - $h) / 2;
                break;
            case 6://6為中部居右
                $posX = $ground_w - $w;
                $posY = ($ground_h - $h) / 2;
                break;
            case 7://7為底端居左
                $posX = 0;
                $posY = $ground_h - $h;
                break;
            case 8://8為底端居中
                $posX = ($ground_w - $w) / 2;
                $posY = $ground_h - $h;
                break;
            case 9://9為底端居右
                $posX = $ground_w - $w - 10;   // -10 是距離右側10px 可以自己調節
                $posY = $ground_h - $h - 10;   // -10 是距離底部10px 可以自己調節
                break;
            default://隨機
                $posX = rand(0,($ground_w - $w));
                $posY = rand(0,($ground_h - $h));
                break;
        }
        //設定影象的混色模式
        imagealphablending($ground_im, true);
        if($isWaterImage)//圖片水印
        {
            imagecopy($ground_im, $water_im, $posX, $posY, 0, 0, $water_w,$water_h);//拷貝水印到目標檔案 
        }
        else//文字水印
        {
            if( !emptyempty($textColor) && (strlen($textColor)==7) )
            {
                $R = hexdec(substr($textColor,1,2));
                $G = hexdec(substr($textColor,3,2));
                $B = hexdec(substr($textColor,5));
            }
            else
            {
                die("水印文字顏色格式不正確!");
            }
            imagestring ( $ground_im, $textFont, $posX, $posY, $waterText, imagecolorallocate($ground_im, $R, $G, $B)); 
        }
        //生成水印後的圖片
        @unlink($groundImage);
        switch($ground_info[2])//取得背景圖片的格式
        {
            case 1:imagegif($ground_im,$groundImage);break;
            case 2:imagejpeg($ground_im,$groundImage);break;
            case 3:imagepng($ground_im,$groundImage);break;
            default:die($errorMsg);
        }
        //釋放記憶體
        if(isset($water_info)) unset($water_info);
        if(isset($water_im)) imagedestroy($water_im);
        unset($ground_info);
        imagedestroy($ground_im);
    }

好啦,這個就好用了。上傳圖片加水印就好用了。

請注意:水印功能需要用到GD庫模組,請檢查下php是否安裝了GD庫模組。

到此這篇關於PHP利用ueditor實現上傳圖片新增水印的文章就介紹到這了,更多相關PHP上傳圖片新增水印內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com