温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

yii2如何自定义组件实现全局使用图片上传功能

发布时间:2021-08-27 09:16:06 来源:亿速云 阅读:134 作者:小新 栏目:开发技术

这篇文章主要介绍了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如何自定义组件实现全局使用图片上传功能”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI