express验证器的国际化(i18n)



是否可以将express验证器返回的消息转换为英语以外的语言进行国际化(i18n)?

我试着查看源代码,但找不到。

快速验证器

感谢

这可能是您必须自己创建的东西,但不应该太难。

当您用withMessage()分配错误消息时,您可以发送多个字符串。例如,您可以发送一个对象。因此,您可以将所有语言、特定错误的错误消息放在对象中。

这里有一个例子:

路线

const countValidation = require('./count.validation');
router
.route('/blogposts')
.get(
countValidation.count,
blogpostController.blogpostsGetAll,
);

验证器(在一个名为count.validation.js的单独文件中)

const message = {
english: 'count must be between 1 and 1000',
chinese: 'count must be between 1 and 1000, but in chinese',
};
module.exports.count = [
check('count')
.optional()
.isInt({ min: 1, max: 1000 })
.withMessage(message)
];

验证失败时将发送此响应:

{
"errors": {
"count": {
"location": "query",
"param": "count",
"value": "-1",
"msg": {
"english": "count must be between 1 and 1000",
"chinese": "count must be between 1 and 1000, but in chinese"
}
}
}
}

在这个特定的示例中,前端必须根据用户设置或用户代理来选择要显示的错误消息。

如果我们从请求中知道客户端使用的是什么语言,那么也可以处理在服务器端使用的错误消息。例如,我们可以读取请求中的accept language标头。下面是一个如何做到这一点的例子:

控制器功能:

而不是使用这个(错误的标准处理,几乎直接从自述文件中):

module.exports.blogpostsGetAll = (req, res) => {
const errors = validationResult(req);
if (!errors.isEmpty()) {
return res.status(422).json({ errors: errors.mapped() });
}
// The rest of the function...
};

我们使用这个:

module.exports.blogpostsGetAll = (req, res) => {
const errors = validationResult(req);
if (!errors.isEmpty()) {
const errorsInProperLanguage = handleLanguages(req.headers, errors.mapped());
return res.status(422).json({ errors: errorsInProperLanguage });
}
// The rest of the function...
};

仅使用一种语言的示例函数:

function handleLanguages(headers, errorsMapped) {
const language = headers['accept-language'].split(',')[0];
for (let errorKey in errorsMapped) {
errorsMapped[errorKey].msg = errorsMapped[errorKey].msg[language];
}
return errorsMapped;
}

因为accept language标头包含语言代码,而不是语言名称,所以我们必须稍微修改消息对象:

const message = {
'en-US': 'count must be between 1 and 1000',
'zh-CH': 'count must be between 1 and 1000, but in chinese',
};

消息对象必须在accept language标头中包含第一语言代码才能工作。handleLanguage函数不处理错误。这只是一个展示如何做到这一点的例子;不要直接使用它。

错误消息将更改为

{
"errors": {
"count": {
"location": "query",
"param": "count",
"value": "-1",
"msg": "count must be between 1 and 1000, but in chinese"
}
}
}

接受语言中的第一种语言是zh-CH时。

这现在可以通过express validator v5.0.0实现。
如果您向withMessage()传递函数,它将被调用,并带有字段值、请求、位置和路径。

文档示例:

check('something').isInt().withMessage((value, { req, location, path }) => {
return req.translate('validation.message.path', { value, location, path });
}),

最新更新