如何使用服务器端验证生成客户端验证?

3
在我的情况下,当服务器端的@Valid失败时,响应会包含每个目标输入的错误消息。因此,我不必编写客户端验证。但我想使用客户端验证来最小化请求。但是,由于我懒,我发现自己基本上要编写两次相同的验证。
是否有一种方法可以使用服务器端验证生成客户端验证?
1个回答

1
如果您在服务器端使用注释进行验证,那么可以基于这些注释生成客户端验证。
示例:
public class MyObject{
   @Size(min=2, max=30, message ="Invalid size")
   private String name;
   //getters & setters
}

如果您正在使用jQuery验证插件,可以在每个字段上添加目标验证。有关更多详细信息,请参见参考文献: https://jqueryvalidation.org/reference/ 您可以查看所有字段并查看其注释:
Field[] fields = MyObject.class.getDeclaredFields();

从它们中获取目标注释:
Map<String, Set<String>> validationsRules = new HashMap<>();
Field field = fields[0]; // here you should iterate over all fields
Size size = field.getAnnotation(Size.class);
Set<String> dataAttributes = new HashSet<>();
dataAttributes.add("data-rule-minlength=" + size.min());
dataAttributes.add("data-rule-maxlength=" + size.max());
dataAttributes.add("data-msg-minlength=" + size.message());
dataAttributes.add("data-msg-maxlength=" + size.message());
validationsRules.put(field.getName(), dataAttributes);

验证规则必须添加到视图中,并附加到每个字段。您的最终HTML将类似于以下内容:
<input name="name" data-rule-minlength=2 data-rule-maxlength=30 data-msg-minlength="Invalid size" data-msg-maxlength="Invalid size"/>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接