3

我们可以在这里阅读如何编写:

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

class MyValid_Float extends Zend_Validate_Abstract
{

1) 我们应该把它放在哪里?

应用程序/默认值/验证器?应用程序/视图/助手/...?

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: (请注意,此配置使用默认模块):

应用程序/默认/验证器/ValidateSpam.php

在 validateSpam.php 上有类似的东西:

class My_Validate_Spam extends Zend_Validate_Abstract {

你能确认一下吗?

谢谢

4

2 回答 2

6

application/validators then 放在应用程序的 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');
   ...
 }
 ...
}
于 2011-06-22T13:14:46.110 回答
1

我通过将以下行添加到 application.ini 来做到这一点:-

autoloadernamespaces[] = "App_"

然后我将我的自定义验证器放在(例如)/library/App/Validate/MyCustomValidator.php 中。

然后我可以使用类似的东西编写我的验证器:-

class App_Validate_MyCustomValidator() extends Zend_Validate_Abstract

它对我来说效果很好,并且简单易实现。

于 2011-06-22T14:51:48.597 回答