gpt4 book ai didi

php - Zend_Validate : Db_NoRecordExists with Doctrine

转载 作者:行者123 更新时间:2023-12-02 06:45:13 25 4
gpt4 key购买 nike

嘿,我正在尝试使用 Zend_Validate 和 Zend_Form 验证表单。

我的元素:

$this->addElement('text', 'username', array(
'validators' => array(
array(
'validator' => 'Db_NoRecordExists',
'options' => array('user','username')
)
)
));

因为我使用 Doctrine 来处理我的数据库,Zend_Validate 缺少一个 DbAdapter。我可以在选项中传递一个适配器,但我如何结合 Zend_Db_Adapter_Abstract 和 Doctrine?

是否有更简单的方法来完成这项工作?

谢谢!

最佳答案

用自己的验证器解决了它:

<?php

class Validator_NoRecordExists extends Zend_Validate_Abstract
{
private $_table;
private $_field;

const OK = '';

protected $_messageTemplates = array(
self::OK => "'%value%' ist bereits in der Datenbank"
);

public function __construct($table, $field) {
if(is_null(Doctrine::getTable($table)))
return null;

if(!Doctrine::getTable($table)->hasColumn($field))
return null;

$this->_table = Doctrine::getTable($table);
$this->_field = $field;
}

public function isValid($value)
{
$this->_setValue($value);

$funcName = 'findBy' . $this->_field;

if(count($this->_table->$funcName($value))>0) {
$this->_error();
return false;
}

return true;
}
}

这样使用:

$this->addElement('text', 'username', array(
'validators' => array(
array(
'validator' => new Validator_NoRecordExists('User','username')
)
)
));

关于php - Zend_Validate : Db_NoRecordExists with Doctrine,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1395947/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com