时间:2021-05-25
本文讲述了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); ?>更多关于Yii相关内容感兴趣的读者可查看本站专题:《Yii框架入门及常用技巧总结》、《php优秀开发框架总结》、《smarty模板入门基础教程》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了YII2框架自定义全局函数的方法。分享给大家供大家参考,具体如下:有些时候我们需要自定义一些全局函数来完成我们的工作。方法一:直接写在入口文件处r
简介实现功能自定义文本自定义类型(默认,消息,成功,警告,危险)自定义过渡时间使用vue-cli3.0生成项目toast全局组件编写/src/toast/toa
JS代码实现自定义热键实现功能:1.自定义上下左右键2.使用自定义热键或者使用键盘上下左右键移动图片效果图:步骤1:HTML代码:使用自定义按键实现图片移动ta
1.Vue指令 Vue提供自定义实现指令的功能,和组件类似,可以是全局指令和局部指令,详细可以参见vue官网自定义指令一节(https://cn.vuejs.
本文实例讲述了YII2框架中添加自定义模块的方法。分享给大家供大家参考,具体如下:有些时候系统功能过于复杂,这时我们需要通过模块把一些功能区分开来,便于管理与维