Zend_Validate: Db_NoRecordExists with Doctrine [英] Zend_Validate: Db_NoRecordExists with Doctrine

查看:16
本文介绍了Zend_Validate: Db_NoRecordExists with Doctrine的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

您好,我正在尝试使用 Zend_Validate 和 Zend_Form 验证表单.

Hey there, I'm trying to validate a form with Zend_Validate and 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?

For I use Doctrine to handle my database, Zend_Validate misses a DbAdapter. I could pass an adapter in the options, but how do I combine Zend_Db_Adapter_Abstract and Doctrine?

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

Is there maybe an easyer way to get this done?

谢谢!

推荐答案

用自己的验证器解决了:

Solved it with an own Validator:

<?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')
            )
    )
));

这篇关于Zend_Validate: Db_NoRecordExists with Doctrine的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆