Zend Framework - Где мы должны разместить наши специальные валидаторы? - PullRequest
3 голосов
/ 22 июня 2011

Здесь мы можем прочитать, как написать:

http://framework.zend.com/manual/en/zend.validate.writing_validators.html

class MyValid_Float extends Zend_Validate_Abstract
{

1) Где мы должны разместить это?

приложение/ по умолчанию / валидаторы?application / view / helpers / ...?

2) Нужно ли регистрировать это где-нибудь в нашем приложении?

Обновление: Вотпример моей начальной загрузки:

include_once 'config_root.php';
set_include_path ( $PATH );

require_once 'Initializer.php';
require_once "Zend/Loader.php";
require_once 'Zend/Loader/Autoloader.php';

// Set up autoload.
$loader = Zend_Loader_Autoloader::getInstance ();
$loader->setFallbackAutoloader ( true );
$loader->suppressNotFoundWarnings ( false );

// Prepare the front controller.
$frontController = Zend_Controller_Front::getInstance ();
$frontController->throwExceptions(true);
$frontController->registerPlugin ( new Initializer ( PROJECT_ENV ) );

// Dispatch the request using the front controller.
try {
    $frontController->dispatch ();

} catch ( Exception $exp ) {
    $contentType = "text/html";
    header ( "Content-Type: $contentType; charset=UTF-8" );
    echo "an unexpected error occurred.";
    echo "<h2>Unexpected Exception: " . $exp->getMessage () . "</h2><br /><pre>";
    echo $exp->getTraceAsString ();
}

ТАК, мне нужно добавить сюда:

$resourceLoader = new Zend_Loader_Autoloader_Resource(array(
    'basePath'  => APPLICATION_PATH,
    'namespace' => '',
));

$resourceLoader->addResourceType('validate', 'validators/', 'My_Validate_');

И тогда я должен создать файл IN: (обратите внимание, что эта конфигурация использует по умолчаниюмодуль):

application / default / validators / ValidateSpam.php

А на validateSpam.php есть что-то вроде:

class My_Validate_Spam extends Zend_Validate_Abstract {

Можете ли выпожалуйста подтвердите?

Спасибо

Ответы [ 2 ]

6 голосов
/ 22 июня 2011

Поместите application/validators, затем в класс Bootstrap вашего приложения добавьте следующую функцию:

protected function _initAutoload () {

        // configure new autoloader
        $autoloader = new Zend_Application_Module_Autoloader (array ('namespace' => '', 'basePath' => APPLICATION_PATH));

        // autoload validators definition
        $autoloader->addResourceType ('Validator', 'validators', 'Validator_');
}

Подробнее о Автозагрузка Zend Bootstrap ,

Другой способ описан в этом блоге, где конструктор контроллера для формы, использующей этот пользовательский валидатор, имеет дополнительную строку:

class JD_Form_Controller extends Zend_Form
{
 public function __construct($options = null)
 {        
   // path setting for custom classes MUST ALWAYS be first!
   $this->addElementPrefixPath('JD_Form_Validator','JD/Form/Validator','validate');
   ...
 }
 ...
}
1 голос
/ 22 июня 2011

Я делаю это, добавляя следующую строку в application.ini: -

autoloadernamespaces[] = "App_"

Затем я помещаю свои собственные валидаторы в (например) /library/App/Validate/MyCustomValidator.php.

Затем я могу написать свой валидатор, используя что-то вроде: -

class App_Validate_MyCustomValidator() extends Zend_Validate_Abstract

Он работает довольно хорошо для меня, прост и легок в реализации.

...