为什么数据不能保存?

时间:2017-10-04 07:02:38

标签: php yii2

我想处理表单并从表单中保存数据做我的数据库。 我希望在保存之前从表单和其他数据中获取一些数据(如当前的user_id,当前日期时间)。我在Controller中创建了方法:

public function actionCreate()
    {
        $model = new Post();
        if ($model->load(\Yii::$app->request->post()) && $model->validate()) {
            $model->user_id = \Yii::$app->user->getId();
            $model->created_at = \Yii::$app->formatter->asDate(new \DateTime(),'php:Y-m-d');
            $model->image = UploadedFile::getInstance($model, 'image');
            if($model->upload()) {
                $model->image = ('web/images/' . $model->image->baseName . '.' . $model->image->extension);
            } else {
                $model->image = 0;
            }
            $model->save();
            return $this->redirect(['site/blog']);
        } else {
            return $this->render('blog/create', ['model' => $model]);
        }
    }

和我的帖子模型:

class Post extends ActiveRecord
{
    public $title;
    public $text;
    public $image;
    public $comments;

    public function rules()
    {
        return [
            [['title', 'text'], 'required'],
            [['image'], 'file',  'extensions' => 'png, jpg'],
        ];
    }
    public function upload()
    {
        if ($this->image->saveAs(\Yii::getAlias('@app') .'\web\images\\' . $this->image->baseName . '.' . $this->image->extension))
            return true;
        else {
            return false;
        }
    }
    public function getUser()
    {
        return $this->hasOne(User::className(),['id' => 'user_id']);
    }
}

但现在当我发送我的表单时只有user_id,created_at,保存在我的数据库中。我做错了什么?

1 个答案:

答案 0 :(得分:2)

删除它:

public $title;
public $text;
public $image;
public $comments;

从你的模特。就这样。 ActiveRecord会自动映射表格中的列。