您好,登錄后才能下訂單哦!
這篇文章主要介紹了yii2如何自定義組件實現全局使用圖片上傳功能,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
具體如下:
此例為yii2高組應用,這里只提供一個簡單的事例
在yii2中,在使用到上傳圖片時有自帶的一個上傳圖片類,但不太好用。
其中有一種方式,把自己寫的一個上傳圖片類文件,注冊成一個組件,在全局中使用。(我記得我在里面有寫過一篇小物件的使用)
這里,我只作一個簡單的自定義組件介紹
1、在backend(或frontend)定義一個 upload.php(注意路徑: backend/components)
//圖片上傳處理類(這里略) //upload.php事例代碼 namespace backend\components; class Upload { public function test(){ $a = '你好'; return $a; } }
2、backend/config/main.php 注冊剛寫的自定義組件
'components' => [ 'imgload' => [ 'class' => 'backend\components\Upload' ], ]
3、控制器中如何使用
public function actionArticlelist() { $cc = Yii::$app->imgload->test(); var_dump($cc);exit; }
那么,一個完整的圖片上傳組件這里就不寫了。
這里只寫了一個使用自定義組件的方法!
還是補進進來吧。
1、自定義組件,便于全局使用。backend/config/main.php
'components' => [ 'user' => [ 'identityClass' => 'common\models\AgMerch', 'enableAutoLogin' => true, ], //自定義圖片上傳類 'imgload' => [ 'class' => 'agent\components\Upload' ], ]
2、自定義圖片上傳類 backend/components/Upload.php
namespace agent\components; use yii; use yii\base\Object; use yii\web\UploadedFile; class Upload extends Object { /** * [UploadPhoto description] * @param [type] $model [實例化模型] * @param [type] $path [圖片存儲路徑] * @param [type] $originName [圖片源名稱] * @param boolean $isthumb [是否要縮略圖] */ public function UploadPhoto($model,$path,$originName,$isthumb=false){ $root = $_SERVER['DOCUMENT_ROOT'].'/'.$path; //返回一個實例化對象 $files = UploadedFile::getInstance($model,$originName); $folder = date('Ymd')."/"; $pre = rand(999,9999).time(); if($files && ($files->type == "image/jpeg" || $files->type == "image/pjpeg" || $files->type == "image/png" || $files->type == "image/x-png" || $files->type == "image/gif")) { $newName = $pre.'.'.$files->getExtension(); }else{ die($files->type); } if($files->size > 2000000){ die("上傳的文件太大"); } if(!is_dir($root.$folder)) { if(!mkdir($root.$folder, 0777, true)){ die('創建目錄失敗...'); }else{ // chmod($root.$folder,0777); } } //echo $root.$folder.$newName;exit; if($files->saveAs($root.$folder.$newName)) { if($isthumb){ $this->thumbphoto($files,$path.$folder.$newName,$path.$folder.'thumb'.$newName); return $path.$folder.$newName.'#'.$path.$folder.'thumb'.$newName; }else{ return $path.$folder.$newName; } } } }
3、控制器部分
use backend\components\Upload; public function actionArtadd(){ $model = new Article(); if ($model->load(Yii::$app->request->post())) { //cover為表中的字段名 $img = Yii::$app->imgload->UploadPhoto($model,'uploads/article/','cover'); $model->cover = $img;//存入表中 if($model->save()){ Yii::$app->getSession()->setFlash('info', '添加成功!'); return $this->redirect(['xxx']); }else{ Yii::$app->getSession()->setFlash('info', '添加失敗!'); @unlink($img); return $this->redirect(['xxx']); } } //代碼略 }
4、視圖 (部分代碼)
<?= $form->field($model, 'cover', [ 'options'=>['class'=>''], 'inputOptions' => ['class' => 'form-control'], ])->fileInput()->label(false); ?>
感謝你能夠認真閱讀完這篇文章,希望小編分享的“yii2如何自定義組件實現全局使用圖片上傳功能”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。