91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

昌都县| 邳州市| 玉溪市| 专栏| 曲周县| 枣强县| 时尚| 永登县| 永新县| 涡阳县| 奇台县| 桂东县| 广宗县| 金沙县| 枞阳县| 鲁甸县| 忻州市| 绥芬河市| 西贡区| 衡水市| 莒南县| 南城县| 长沙市| 焦作市| 威海市| 马鞍山市| 湘潭市| 尚志市| 乌拉特中旗| 阿克苏市| 祁连县| 湘阴县| 嘉定区| 隆尧县| 贡嘎县| 宝丰县| 射阳县| 儋州市| 福清市| 永德县| 睢宁县|