亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

yii2如何自定義組件實現全局使用圖片上傳功能

發布時間:2021-08-27 09:16:06 來源:億速云 閱讀:120 作者:小新 欄目:開發技術

這篇文章主要介紹了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

唐河县| 朝阳区| 吉水县| 阿城市| 卢湾区| 金寨县| 龙南县| 綦江县| 夹江县| 子长县| 富源县| 左贡县| 宜城市| 旌德县| 绥滨县| 濉溪县| 宁城县| 海南省| 黄石市| 基隆市| 六枝特区| 封开县| 灯塔市| 萨迦县| 三台县| 沂水县| 徐汇区| 松滋市| 浮山县| 兴城市| 太康县| 墨竹工卡县| 平塘县| 延安市| 贡觉县| 定结县| 剑河县| 甘肃省| 克山县| 眉山市| 郧西县|