多次调用 Cakephp 回调函数

Cakephp Callback function called multiple times

首先是一些背景信息:

用户可以填写一些输入文本框并上传多张图片(在一个上传字段中)。提交表单后,文本字段中的文本以 $this->XXX->save() 保存在数据库中。此外,数据(特别是来自文件上传的图像)在回调函数 afterSave() 中进行处理。到目前为止一切顺利。

现在问题来了:

回调函数似乎被调用了多次(每上传一张图片调用1次)。所以问题是,第一次一切都很好,但是之后 $this->data 数组基本上是空的(所有文本字段都是 = '')所以回调函数抛出一些异常,因为没有数据。我通过检查 isset() 等解决了问题,但我认为这并没有解决问题。

所以我的问题是,为什么多次调用回调函数,我该如何防止?

编辑: 以下是一些相关的代码片段:

控制器:

      if ($this->request->is('post') || $this->request->is('put')) {

        if($aid==null) $this->Article->create();
        if ($this->Article->save($this->data)) {
            $this->Session->setFlash(__('The article has been saved'), 'flash_custom');
            return $this->redirect(array('controller' => 'articles', 'action' => 'view', $this->id));
        } ...

型号:

我认为其中大部分与此无关。通常我将数据发送到其他模型,这些模型将这些数据保存在其他数据库表中,例如图片

 if ($this->data['Article']['picture']) {
   foreach ($this->data['Article']['picture'] as $picture) {
       if (is_uploaded_file($picture['tmp_name']) && (substr($picture['type'], 0, 5) == "image") && $numberOfPictures < $pictures_allowed) {
           $this->Picture->addPicture($picture, $this->id);
       }
       $numberOfPictures++;
   }

错误转储:

我认为 $this->data 数组的转储在这里很有趣(解释如下)

array(
'Article' => array(
    'pictures' => '0',
    'title' => 'Error Test',
    'abstract' => 'Test abstract',
    'body' => 'Testtext',
    'picture' => array(
        (int) 0 => array(
            [maximum depth reached]
        ),
        (int) 1 => array(
            [maximum depth reached]
        ),
        (int) 2 => array(
            [maximum depth reached]
        )
    ),
    'modified' => '2015-04-13 22:00:09',
    'created' => '2015-04-13 22:00:09',
    'id' => '294'
))


Notice (8): Undefined index: title [APP/Model/Article.php, line 723]
Notice (8): Undefined index: body [APP/Model/Article.php, line 724]
Notice (8): Undefined index: abstract [APP/Model/Article.php, line 725]

array(
    'Article' => array(
        'id' => '294',
        'pictures' => (int) 1,
        'modified' => '2015-04-13 22:00:09',
        'title' => '',
        'body' => '',
        'abstract' => '',
    )
)

Notice (8): Undefined index: picture [APP/Model/Article.php, line 777]

Notice (8): Undefined index: title [APP/Model/Article.php, line 723]

Notice (8): Undefined index: body [APP/Model/Article.php, line 724]

Notice (8): Undefined index: abstract [APP/Model/Article.php, line 725]

array(
    'Article' => array(
        'id' => '294',
        'pictures' => (int) 2,
        'modified' => '2015-04-13 22:00:10',
        'title' => '',
        'body' => '',
        'abstract' => '',
    )
)

Notice (8): Undefined index: picture [APP/Model/Article.php, line 777]

Notice (8): Undefined index: title [APP/Model/Article.php, line 723]

Notice (8): Undefined index: body [APP/Model/Article.php, line 724]

Notice (8): Undefined index: abstract [APP/Model/Article.php, line 725]

array(
    'Article' => array(
        'id' => '294',
        'pictures' => (int) 3,
        'modified' => '2015-04-13 22:00:10',
        'title' => '',
        'body' => '',
        'abstract' => '',
    )
)

Notice (8): Undefined index: picture [APP/Model/Article.php, line 777]

解释:

我刚刚转储 $this->data 一次,但就像你看到的那样,我上传了 3 张图片,我收到了 3 个 afterSave 调用,所以有 3 个 $this->data 转储。第一次一切都很好,但之后会抛出一些警告,因为数组不再填充了。

我希望这些附加信息能对您有所帮助

如果您通过同一模型的后保存回调调用 Model::save,那么它将是递归保存,因为后保存将调用保存,这将再次触发后保存..

在保存后使用的保存方法中禁用回调

$this->save($data, array('callbacks' => false));

Documentation