[英]Server and client side validators - library
什么是在服务器和客户端上验证对象的最佳库? 我正在搜索更简单的东西-一个简单的配置文件,然后在两侧都类似:
var is_valid =验证(object,validationRule);
但是它应该有许多验证选项,例如:
obj: A, B, C, D;
A = something;
B, C - Required;
D - Not needed/hidden
D = something:
C - Required;
B - optional/has value
A - Not needed/hidden
在客户端,我使用Aurelia框架。 它有一个验证插件,但我不知道如何在服务器上使用它。 这意味着,我想在服务器和客户端上使用相同的functionValidation和configValidation;
或者,也许-有一个可以与aurelia-validation一起使用的插件?
在服务器上,我使用Node.js作为后端;
我也正在寻找这个-很好,我们不必重复我们的工作。
穰寻找优秀的服务器端验证只(它的权力沃尔玛和PayPal是非常快的) -但它只是有点可以使用它在客户端上。
然后是validate.js ,看起来它可能同时完成这两项工作。
我可以使用此提交作为参考来实现一些东西: https : //github.com/aurelia/validation/commit/1b701ab
我对aurelia来说还很陌生,所以这几乎是一个复制粘贴工作,但它确实有效,所以我想我对此很满意。 这些都是打字稿中的内容,但是您可以了解JS实现的总体思路。
import 'aurelia-polyfills';
import { initialize } from 'aurelia-pal-nodejs';
import { Container } from 'aurelia-dependency-injection';
import { configure as configureBindingLanguage } from 'aurelia-templating-binding';
import { configure as configureValidation, ValidationRules, Validator, Rule, ValidateResult, ControllerValidateResult } from 'aurelia-validation';
import { HandlerError } from 'api/handler.error';
class AureliaValidator {
private validator: Validator
constructor() {
initialize();
const container = new Container();
configureBindingLanguage({ container });
configureValidation({ container });
this.validator = container.get(Validator);
}
validateObject(object: any, rules: Rule<any, any>[][]): Promise<ValidateResult[]> {
return this.validator.validateObject(object, rules).then(results => {
let isValid = results.every(r => r.valid);
let errors = results.map(r => r.message).filter(m => !!m);
if (!isValid) throw new Error(errors[0]);
return results;
});
}
}
export const aureliaValidator = new AureliaValidator();
然后按如下方式使用
import { ValidationRules } from 'aurelia-validation';
import { aureliaValidator } from "validator.ts";
let foo = {
bar: undefined
}
let rules = ValidationRules.ensure('bar').required().rules
// This will fail
aureliaValidator.validateObject(req.body, rules)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.