Я дал проверку в модели. Кроме того, я дал некоторую проверку в контроллере для проверки кода капчи. После этого приложение не отображает ошибки проверки допустимости модели. Если я комментирую код контроллера, проверка допустимости модели хорошо работает и отображает ошибки. Оба не работа..
Типовой кодекс (образец)
class User extends AppModel {
var $name = 'User';
var $validate = array(
'username' => 'notempty',
'firstname' => 'notempty'
);
}
Код контроллера
if (!empty($this->data)) {
$this->User->set($this->data);
$this->User->create();
$captcha = $this->Session->read('CAPTCHA_CODE');
if (strtolower($captcha) != strtolower($this->data['User']['captcha']))
{
$this->User->invalidate('captcha', __('Sorry, your entry did not match', true));
}
if ($this->User->save($this->data, array('validate' => 'only')))
{
if ($this->User->save($this->data, array('validate' => 'false'))) {
$this->Session->setFlash(__('Registered successfully', true));
$this->redirect('success');
}
}else {
$this->Session->setFlash(__('Please, try again.', true));
}
}
Я заменил if ($this->User->save($this->data, array('validate' => 'only')))
строка с if ($this->User->validates())
, затем также это не работает.
помогите
Ваш код должен работать с if ($ this-> User-> validates ())
.У вас проблемы с неправильным поведением, потому что Model :: save ()
сбрасывает член Model :: validationErrors
, стирая вашу пользовательскую ошибку проверки. Model :: validates ()
не работает, поэтому ваша настройка двойной проверки должна работать.
Например, в CakePHP 1.2 следующие функции работают правильно.
Модель:
class User extends AppModel
{
var $validate = array(
'my_other_field' => array(
'rule' => 'notEmpty',
'message' => 'This field should not be empty.'
)
);
}
Контроллер:
class UsersController extends AppModel
{
function add()
{
if (! empty($this->data)) {
$this->User->set( $this->data );
if ( 'foo' != $this->data['User']['my_field'] ) {
$this->User->invalidate( 'my_field', 'Should be "foo".' );
}
if ( $this->User->validates() ) {
$this->flash('Form validated correctly.'); exit;
}
}
}
}
Представление:
<?php echo $form->create('User', array('action'=>'add')); ?>
<?php echo $form->input('User.my_field', array('value'=>'bar')); ?>
<?php echo $form->input('User.my_other_field', array('value'=>'')); ?>
<?php echo $form->end('Submit'); ?>
Представленные как есть выше, ошибки проверки формы появляются под обоими полями, одно предоставляется логикой проверки контроллера, а другое - правилами проверки модели.
Более серьезной проблемой, конечно же, является запутывание ролей MVC из-за того, что контроллер выполняет некоторую проверку данных. Вы можете рассмотреть что-то вроде этого:
Контроллер:
class UsersController extends AppController
{
function add()
{
if (! empty($this->data)) {
$captcha = $this->Session->read('CAPTCHA_CODE');
$this->User->setCaptchaCheck( $captcha );
if ( $this->User->save( $this->data, array('validate'=>true))) {
$this->Session->setFlash('Success');
$this->redirect('success',303,true);
}
}
}
}
Модель:
class User extends AppModel
{
var $captchaCheck = '';
var $validates = array(
'captcha' => array(
'matchesCheck' => array(
'rule' => array( 'matchesCaptchaCheck', 'captchaCheck' ), // second value of array should match class member-name above
'message' => "CAPTCHAs don't match."
)
)
);
function matchesCaptchaCheck( $data, $checkVar )
{
$data = reset(array_values($data)); // I don't need to know the field name now.
return low($data) == low($this->{$checkVar});
}
function setCaptchaCheck( $captcha )
{
$this->captchaCheck = $captcha;
}
}
Теперь ваш контроллер блаженно игнорирует то, как ваша модель проверяет свои данные, и даже как они структурированы; и ваша проверка формы все происходит в модели.
Надеюсь, это поможет.