Yii2创建数据行工作但更新没有

时间:2017-08-13 12:45:04

标签: php yii2

我在类似的问题上看到了一些答案,但仍然无法理解我的问题在哪里。我有一个_form.php,它在创建和更新数据行时使用。当我创建数据行时,它可以,但是当它将我重定向到return $this->redirect(['view', 'id' => $model->id]);时,但数据不会更新。试图var_dump($model->getErrors())(正如我在另一个问题的答案中看到的那样),但它返回我并清空array。 这些是我的文件: 控制器动作:

public function actionUpdate($id)
    {
        $model = $this->findModel($id);
        $settings = new Settings();

        if ($model->load(Yii::$app->request->post()) && $model->save()) {
            $languages = Lang::find()->all();
            foreach ($languages as $language) {
                if ($language->default != 1) {

                    $names = 'names_' . $language->url;
                    $varNames = Yii::$app->OutData->sanitize($model->$names);
                    $model->$names = $varNames;

                    $review = 'review_' . $language->url;
                    $varReview = Yii::$app->OutData->sanitize($model->$review);
                    $model->$review = $varReview;

                    $metaDesc = 'meta_desc_' . $language->url;
                    $varMetaDesc = Yii::$app->OutData->sanitize($model->$metaDesc);
                    $model->$metaDesc = $varMetaDesc;

                    $url = 'url_' . $language->url;
                    $varUrl = Yii::$app->OutData->sanitize($model->$url);
                    $model->$url = $varUrl;

                    $cBirth = 'country_birth_' . $language->url;
                    $varcBirth = Yii::$app->OutData->sanitize($model->$cBirth);
                    $model->$cBirth = $varcBirth;
                }
                else
                {
                    $model->names = Yii::$app->OutData->sanitize($model->names);
                    $model->review = Yii::$app->OutData->sanitize($model->review);
                    $model->meta_desc = Yii::$app->OutData->sanitize($model->meta_desc);
                    $model->url= Yii::$app->OutData->sanitize($model->url);
                    $model->country_birth = Yii::$app->OutData->sanitize($model->country_birth);
                }
            }

            //записване на изображенията + thumb
            if (isset($_POST["Author"]["imageFiles"]) and ! empty($_POST["Author"]["imageFiles"])) {

                $model->imageFiles = UploadedFile::getInstances($model, 'imageFiles');
                if (isset($model->imageFiles) and count($model->imageFiles) > 0) {
                    foreach ($model->imageFiles as $key => $file) {
                        $parseProdTitle = MakeURL::parseImageName($model->names.'_'.$model->id);
                        $fileName = $parseProdTitle . '_' . $model->id . '.' . $file->extension;
                        $fileName = Yii::$app->translate->cyr_to_lat($fileName);
                        $model->filename = $fileName;
                        $model->save(false);
                        $pic = Yii::getAlias('@frontend/web') . '/authors/thumb-270/' . $fileName;
                        $pic2 = Yii::getAlias('@frontend/web') . '/authors/' . $fileName;
                        $file->saveAs(Yii::getAlias('@frontend/web') . '/authors/' . $fileName);
                        $image = file_get_contents(Yii::getAlias('@frontend/web') . '/authors/' . $fileName);
                        file_put_contents($pic, $image);
                        $model->resizeImg($pic);
                        $settings->compress($pic, $pic, 90);
                        $settings->compress($pic2, $pic2, 90);
                    }
                }
            }

           if($model->update()){
               var_dump(1);die;
           }else{
               var_dump($model->getErrors());die;// it dumps here but it returns an empty array
           }

           if($model->validate()){
               var_dump(1);die;// it dumps here so validate is ok ( I guess )
           }else{
               var_dump($model->getErrors());die;
           }


            return $this->redirect(['view', 'id' => $model->id]);
        } else {
            return $this->render('update', [
                'model' => $model,
            ]);
        }
    }

我的模特:

<?php

namespace backend\models;

use Yii;
use omgdef\multilingual\MultilingualBehavior;
use omgdef\multilingual\MultilingualQuery;
use kartik\helpers\Html;

/**
 * This is the model class for table "author".
 *
 * @property integer $id
 * @property integer $active
 * @property string $filename
 * @property integer $sort
 * @property data $birthday
 *
 * @property AuthorLang[] $authorLangs
 */
class Author extends \yii\db\ActiveRecord
{
    public $imageFiles;
    private $languages = array();

    public function __construct() {
        foreach(Yii::$app->params['languages'] as $langArr){
            $langParam = new Lang;
            $langParam->id = $langArr['id'];
            $langParam->url = $langArr['url'];
            $langParam->local = $langArr['local'];
            $langParam->name = $langArr['name'];
            $langParam->default = $langArr['default'];
            $langParam->active = $langArr['active'];
            $this->languages[] = $langParam;
        }
        parent::__construct();
    }

    public static function find()
    {
        return new MultilingualQuery(get_called_class());
    }

    public function behaviors()
    {
        $languagesArray = [];
        foreach($this->languages as $language){
            if($language->default){
                $defLang = $language->url;
            }
            $languagesArray[$language->local] = $language->name;
        }

        return [
            'ml' => [
                'class' => MultilingualBehavior::className(),
                'languages' => $languagesArray,
                //'languageField' => 'language',
                //'localizedPrefix' => '',
                //'requireTranslations' => false',
                //'dynamicLangClass' => true',
                //'langClassName' => PostLang::className(), // or namespace/for/a/class/PostLang
                'defaultLanguage' => $defLang,
                'langForeignKey' => 'author_id',
                'tableName' => "{{%authorLang}}",
                'attributes' => [
                    'names',
                    'review',
                    'meta_desc',
                    'url',
                    'country_birth',
                ]
            ],
        ];
    }

    /**
     * @inheritdoc
     */
    public static function tableName()
    {
        return 'author';
    }

    /**
     * @inheritdoc
     */
    public function rules()
    {
        $required = ['names', 'review', 'meta_desc', 'url', 'birthday', 'country_birth'];

        $this->checkLanguage([$required]);

        return [
            [['active', 'sort'], 'required'],
            [$required, 'required'],
            ['names', 'string', 'max' => 255],
            ['country_birth', 'string', 'max' => 255],
            ['review', 'string'],
            ['meta_desc', 'string', 'max' => 170],
            ['url', 'string', 'max' => 60],
            [['active', 'sort'], 'integer'],
            [['filename'], 'string'],
        ];
    }

    protected function checkLanguage($megaArr = [])
    {
        foreach ($this->languages as $language)
        {
            if($language->default != 1)
            {
                foreach ($megaArr as $fields)
                {
                    foreach ($fields as $field)
                    {
                        $field .= '_' . $language->url;
                    }
                }
            }
        }
    }

    public function changeActiveForm() {
        $active = "";
        if ($this->active == 1) {
            $active = 'checked="checked"';
        }
        return '<label class="switch switch-custom block mbn taCenter">
                <input type="checkbox" value="1" id="check_' . $this->id . '" name="field_types" class="legend-switch" ' . $active . ' onchange="changeStatusActive(' . $this->id . ', \'author\');"></input>
                <label data-off="' . Yii::t('app', 'Не') . '" data-on="' . Yii::t('app', 'Да') . '" for="check_' . $this->id . '"></label>
                <span></span>
            </label>';
    }

    public function getKartikImagesList() {
        $doctorImagesArr = array();
        $doctorImages = Author::find()->where('id = :id', [':id' => $this->id])->orderBy(['id' => SORT_ASC])->one();
        if(isset($doctorImages->filename) and $doctorImages->filename!="" and $doctorImages->filename!=Null) {
            $fileName = Yii::getAlias('@frontend/web') . "/authors/" . $doctorImages->filename;
            if (file_exists($fileName)) {
                $fileNameUrl = Yii::$app->urlManagerFrontend->baseUrl . "/authors/thumb-270/" . $doctorImages->filename;
                $doctorImagesArr[] = Html::img($fileNameUrl, ['class' => 'file-preview-image', 'style' => 'width: 350px;']) .
                    '<a href="javascript://" onclick="deleteAuthorImage(' . $this->id . ')"><span class="glyphicons glyphicons-bin"></span></a>';
            }
        }
        return $doctorImagesArr;
    }

    public function resizeImg($img) {
        $sz = getimagesize($img);
        $ratio = $sz[0] / $sz[1]; // w/h

        $w2 = Yii::$app->params['thumbswidth']; // thumb 1 width

        $image = new SimpleImage();

        $image->load($img);

        $image->resize($w2, round($w2 / $ratio));
        $image->save($img);
    }

    /**
     * @inheritdoc
     */
    public function attributeLabels()
    {
        return [
            'id' => 'ID',
            'active' => Yii::t('app','app.Active' ),
            'filename' => Yii::t('app','app.Filename' ),
            'sort' => Yii::t('app','app.Sort' ),
            'country_birth' => Yii::t('app','app.Birth Country' ),
            'names' => Yii::t('app','app.Names' ),
            'meta_desc' => Yii::t('app','app.Meta Desc' ),
            'filename' => Yii::t('app','app.Image' ),
            'birthday' => Yii::t('app','app.Birthday' ),
            'imageFiles' => Yii::t('app','app.Image' ),
            'description' => Yii::t('app','app.Review' ),
        ];
    }

    /**
     * @return \yii\db\ActiveQuery
     */
    public function getAuthorLangs()
    {
        return $this->hasMany(AuthorLang::className(), ['author_id' => 'id']);
    }
}

我没有发布_form.php,因为两个动作(创建和更新)都是一样的,我认为问题不在其中。如果你需要它会立即更新我的问题。提前谢谢!

1 个答案:

答案 0 :(得分:1)

由于某种原因,更新可能不会影响表中的任何行。在这种情况下,函数返回0 ..以检查这种情况你应该这样解决

http://www.yiiframework.com/doc-2.0/yii-db-activerecord.html#update()-detail

 if($model->update() !== false){
           var_dump(1);die;
       }else{
           var_dump($model->getErrors());die;// it dumps here but it returns an empty array
       }

然后,仅用于调试,您也可以尝试使用$model->save(false)而不是$model->update() ...这样就可以保存$ model而不考虑验证规则..