我们可以在这里阅读如何写:
http://framework.zend.com/manual/en/zend.validate.writing_validators.html
class MyValid_Float extends Zend_Validate_Abstract
{
1) 我们应该把它放在哪里?
application / default / validators? 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 :(请注意,此配置使用默认模块):
应用/默认/验证/ ValidateSpam.php
在validateSpam.php上有类似的内容:
class My_Validate_Spam extends Zend_Validate_Abstract {
你能确认一下吗?
由于
答案 0 :(得分:6)
放置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 Autoloading 的更多详细信息。
另一种方式在this博客中有描述,其中使用此自定义验证程序的表单的控制器的构造函数有一个额外的行:
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 :(得分:1)
我是通过在application.ini中添加以下行来实现的: -
autoloadernamespaces[] = "App_"
然后我将自定义验证器放在(例如)/library/App/Validate/MyCustomValidator.php中。
然后我可以使用以下内容编写验证器: -
class App_Validate_MyCustomValidator() extends Zend_Validate_Abstract
它对我来说非常好用,并且简单易用。