Zend框架3 - 翻译验证消息

问题描述 投票:0回答:3

我需要翻译验证消息。

我找到了这个链接

https://zendframework.github.io/zend-validator/messages/

在我的全局配置中,我有这个

'translator' => [
        'locale' => ['it_IT','en_US'],
        'translation_file_patterns' => [
            [
                'type'     => 'gettext',
                'base_dir' => getcwd() .  '/data/language',
                'pattern'  => '%s.mo',
            ],
        ],
    ],

在视图转换器中,使用__('key'),工作正常。但验证信息仍为英文

我使用网站指南验证表单这是我的代码

<?php

namespace Admin\Model;

// Add the following import statements:
use DomainException;
use Zend\Filter\StringTrim;
use Zend\Filter\StripTags;
use Zend\Filter\ToInt;
use Zend\InputFilter\InputFilter;
use Zend\InputFilter\InputFilterAwareInterface;
use Zend\InputFilter\InputFilterInterface;
use Zend\Validator\NotEmpty;
use Zend\Validator\StringLength;

class LoginModel implements InputFilterAwareInterface
{
    public $username;
    public $user2;

    private $inputFilter;

    .....

    public function getInputFilter()
    {
        if ($this->inputFilter) {
            return $this->inputFilter;
        }

        $inputFilter = new InputFilter();

        $inputFilter->add([
            'name' => 'username',
            'required' => true,
            'validators' => [
                [
                    'name' => NotEmpty::class
                ],
            ],
        ]);

        $inputFilter->add([
            'name' => 'user2',
            'required' => true,
            'validators' => [
                [
                    'name' => NotEmpty::class,
                ],
            ],
        ]);

        $this->inputFilter = $inputFilter;
        return $this->inputFilter;
    }
}

我把上面链接的代码放在哪里?

回答评论

我引用了一个zend i18n验证器文档。但我不明白这个代码放在哪里。我有更多形式来验证

$translator = new Zend\Mvc\I18n\Translator();
$translator->addTranslationFilePattern(
    'phpArray',
    Resources::getBasePath(),
    Resources::getPatternForValidator()
);

AbstractValidator::setDefaultTranslator($translator);
validation zend-framework3
3个回答
1
投票

您可以在验证器的选项中添加消息。像这样:

$inputFilter->add([
    'name' => 'user2',
    'required' => true,
    'validators' => [
        [
            'name' => NotEmpty::class,
            'options' => [
                'messages' => [
                    'messageKey'  => 'non-translated message',
                    'messageKey2' => _('translated message'),
                ],
            ],
        ],
    ],
]);

要覆盖Zend的消息,您可能希望使用Validators中使用的常量。例如。你的问题使用NotEmpty验证器。如果您查看该课程,您会发现:

/**
 * @var array
 */
protected $messageTemplates = [
    self::IS_EMPTY => "Value is required and can't be empty",
    self::INVALID  => "Invalid type given. String, integer, float, boolean or array expected",
];

因此,当您定义上面显示的自定义消息时,您最好这样做:

'messages' => [
    NotEmpty::IS_EMPTY => 'non-translated message',
    NotEmpty::INVALID  => _('translated message'),
],

请注意:您不需要翻译所有ZF的默认消息,除非您不支持所需的语言。 More info

zend-validator附带超过45种不同的验证器,其中包含200多条失败消息。翻译所有这些消息可能是一项繁琐的工作。为方便起见,zendframework / zend-i18n-resources包中提供了预翻译的消息

该repo here支持的语言


其他问题添加到问题的位置配置启用翻译+翻译

要确保翻译人员知道在何处查找翻译文件,请将以下内容添加到module.config.php中的每个模块:

'translator'      => [
    'translation_file_patterns' => [
        [
            'type'     => 'gettext',                // This uses the php-gettext module
            'base_dir' => __DIR__ . '/../language', // Where the folder with files is in relation to this config file
            'pattern'  => '%s.mo',                  // Update extension for what you use
        ],
    ],
],

要使用此功能,您必须安装转换程序包。我建议你使用Zend Mvc i18n包。

通过将命名空间添加到模块数组:config/modules.config.php,在'Zend\\Mvc\\I18n',文件中启用它

通过composer.json添加并安装模块,将其添加到require列表中。撰写本文时的当前版本包括:

"zendframework/zend-mvc-i18n": "^1.1"

为了确保它将来能够正常工作,最好将这些添加到require中:

"ext-intl":"*",
"ext-gettext":"*",

以上将要求在当前运行的PHP实例中安装intlgettext PHP模块。


下面简单介绍一下模块文件/文件夹结构的设置

Simplified setup


0
投票

好的,我找到了问题的解决方案,特别感谢Rkeet的支持(谢谢)。

文档有些不精确。

这一行

$translator = new Zend\Mvc\I18n\Translator();

生成错误,因为构造函数需要参数。我确实以这种方式更改了行:

$translator = $e->getApplication()->getServiceManager()->get('MvcTranslator');

然后我意识到翻译在这个目录中搜索

vendor\zendframework\zend-i18n-resources\src/../languages/

对于locale it_IT

在那条路径中没有it_IT文件夹,只有“它”。我做了重命名,一切正常。

下面是我的Module.php文件的完整代码

<?php


namespace Admin;

use Zend\I18n\Translator\Resources;
use Zend\Validator\AbstractValidator;
use Zend\Mvc\MvcEvent;


class Module
{
    const VERSION = '3.0.3-dev';

    public function onBootstrap(MvcEvent $e)
    {
        /** @var \Zend\Mvc\I18n\Translator $translator */
        $translator = $e->getApplication()->getServiceManager()->get('MvcTranslator');
        $translator->addTranslationFilePattern(
            'phpArray',
            Resources::getBasePath(),
            Resources::getPatternForValidator()
        );
        AbstractValidator::setDefaultTranslator($translator);
    }

    public function getConfig()
    {
        return include __DIR__ . '/../config/module.config.php';
    }
}

0
投票

如果要将默认ZF3转换用于验证消息,则必须修改“src”文件夹下的“Module.php”文件。

首先使用“require”命令通过composer安装“zend-mvc-i18n”模块:

composer require zendframework/zend-mvc-i18n

然后在“Module.php”中使用此代码以查看意大利语中的验证消息:

    <?php

    namespace Application;

    use Zend\I18n\Translator\Resources;
    use Zend\Mvc\I18n\Translator;
    use Zend\I18n\Translator\Translator as I18nTranslator;
    use Zend\Validator\AbstractValidator;
    use Zend\Mvc\MvcEvent;
    use Zend\Mvc\ModuleRouteListener;

    class Module
    {
        const VERSION = '3.0.3-dev';

        public function onBootstrap(MvcEvent $e)
        {
            $eventManager = $e->getApplication()->getEventManager();
            $moduleRouteListener = new ModuleRouteListener();
            $moduleRouteListener->attach($eventManager);
            $t = new I18nTranslator();
            $t->setLocale('it_IT');
            $translator = new Translator($t);
            $translator->addTranslationFile('phpArray', 'vendor/zendframework/zend-i18n-resources/languages/it/Zend_Validate.php', 'default', 'it_IT');
            AbstractValidator::setDefaultTranslator($translator);
        }
     }

您可以将“it_IT”更改为“es_ES”或“de_DE”以查看其他语言的验证消息。

© www.soinside.com 2019 - 2024. All rights reserved.