我正在使用FluentValidation来验证客户端和服务器端的模型.我是最新版本的:
FluentValidation.MVC5
在写作的时候,这是
5.5.0.0
我有以下验证器,简化:
public class MyviewmodelValidator : AbstractValidator<Myviewmodel> { public MyviewmodelValidator() { RuleFor(x => x.Email) .EmailAddress().WithLocalizedMessage(() => MyResources.Validation_Email_NotValidAddress) .NotEmpty() .WithLocalizedMessage(() => MyResources.Validation_Email); } }
客户端它似乎做了一些基本的验证,例如它不接受任何没有’@’符号两侧的文本的东西,但它会接受像test @ test这样的东西.
发布此数据时出现问题,我的控制器中有以下内容:
if (!ModelState.IsValid) throw new Exception("Model validation error");
由于测试@测试电子邮件地址,这会将模型视为无效并引发错误.所以看来我的前端验证比我的服务器端验证更松懈.
在参考了文档后,它确实声明了Email()方法支持客户端,但是这个服务器端和正在呈现给前端的内容之间似乎存在一些差异.
https://fluentvalidation.codeplex.com/wikipage?title=mvc
如何确保客户端验证与服务器端的电子邮件一样彻底.
解决方法
电子邮件输入的客户端规则(用data-val-email属性修饰)在
jquery.validate plugin core中定义(在页面上搜索’email’字样,你找到RegExp)
Fluent Validation EmailValidator class(也是RegExp)中定义的电子邮件属性的服务器端规则
在生命周期方面,这些项目没有什么共同之处:在任何新版本中,内部正则表达式可以同时在两个项目中变得更加/更不严格,并且如果您的目标是在客户端和服务器上具有相同的规则并使其无论插件是否正常工作/ library version updates – 我的建议是用match()规则替换当前的EmailAddress()规则,并明确指定满足域模型需求的regexp.
更新:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。