0

我想从表单中的特定模型更新两个字段,并且只有两个字段。同一模型上还有许多其他字段将在其他地方得到验证,但这两个字段位于单独的表单上。

我需要他们匹配并且都在场。book_name_confirm未保存在数据库中。

$validator
    ->scalar('book_name')
    ->maxLength('book_name', 255)
    ->requirePresence('book_name')
    ->sameAs('book_name_confirm', 'book_name', 'Book names must match')
    ->allowEmptyString('book_name', false);

最初创建记录时似乎工作正常......但是当仅更新这两个字段时,验证似乎并不适用。

例子:

命名书“蓬松兔子”并确认并查看在数据库中创建的记录。验证按预期进行 - 在确认输入中添加任何其他内容都会返回设置错误。

转到书名更新页面。

输入不匹配的书名并提交,保存新书名。没有抛出错误。可以在 DB 中看到显示的新值。如果您尝试将其留空,则会引发浏览器“不得为空”错误。

表格本身:

<?= $this->Form->create($book) ?>
<fieldset>
    <?php
        echo $this->Form->control('book_name');
        echo $this->Form->control('book_name_confirm', array('label' => 'Confirm book name'));
        ?>
</fieldset>
<?= $this->Form->button(__('Set new book name')) ?>
<?= $this->Form->end() ?>

和控制器:

if ($this->request->is(['patch', 'post', 'put'])){
    //bookTracking is passed through URL, is a UUID 
    $bookQuery = $this->Books->find('all')
        ->where(["tracking =" => $bookTracking]);
    $book = $bookQuery->first();
    //stuff here to handle missing books

    $book->book_name = $this->request->getData("book_name");
    $book->book_name_confirm = $this->request->getData("book_name_confirm");

    $this->Books->save($book);
    //redirect
} 

$book = $this->Books->newEntity();
$this->set(compact('book'));

我想我可以在控制器中进行一些手动验证,但这似乎违背了设置整个验证模型的目的。我错过了什么?

4

1 回答 1

1

当您直接设置值时,不会执行验证;它假定您在创建这些值时知道自己在做什么。相反,请使用以下patchEntity功能:

$book = $this->Books->patchEntity($book, $this->request->getData());
于 2019-04-16T03:13:58.267 回答