时间:2021-05-19
创建项目
使用IDEA创建一个spring-boot项目,依赖选上 web, validation, freemarker 即可
先看看效果
创建实体类
创建并加上注解,代码如下
public class Person implements Serializable { @NotNull @Length(min = 3, max = 10) // username长度在3-10之间 private String username; @NotNull @Min(18) // 年龄最小要18岁 private Integer age; @NotNull // 使用正则来验证字段,message: 设置验证失败的信息 @Pattern(regexp = "[\\w-\\.]+@([\\w-]+\\.)+[a-z]{2,3}", message = "邮箱格式不正确") private String email; public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; }}配置controller
代码:
@Controllerpublic class WebController extends WebMvcConfigurerAdapter { @Override public void addViewControllers(ViewControllerRegistry registry) { //添加一个路由并设置页面名字 registry.addViewController("/results").setViewName("results"); } @GetMapping("/") public String showForm(Person person) { return "form"; } @PostMapping("/") public String checkPersonInfo(@Valid Person person, BindingResult bindingResult, RedirectAttributes redirectAttributes) { // 使用BindingResult来验证表单数据的正确性 if (bindingResult.hasErrors()) { // 将提交的表单内容原封不动的返回到页面再展示出来 redirectAttributes.addFlashAttribute("person", person); return "form"; } return "redirect:/results"; }}注:不要忘了 @Valid 注解
表单页面
表单页面里用到了spring标签来取验证失败的数据,在spring-boot里想用spring标签可以将 spring.ftl 文件在放在 resources 里面,然后在 application.yml 里添加上如下配置即可
spring.ftl 文件路径: org.springframework.web.servlet.view.freemarker.spring.ftl
spring: freemarker: settings: auto_import: /spring.ftl as spring表单页面代码
<form action="/" method="post"> <div class="form-group"> <label for="username">username</label> <@spring.bind "person.username"/> <input type="text" id="username" name="username" value="${person.username!}" class="form-control" placeholder="username"/> <span class="text-danger"><@spring.showErrors ""/></span> </div> <div class="form-group"> <label for="age">age</label> <@spring.bind "person.age"/> <input type="number" id="age" name="age" value="${person.age!}" class="form-control" placeholder="age"/> <span class="text-danger"><@spring.showErrors ""/></span> </div> <div class="form-group"> <label for="email">email</label> <@spring.bind "person.email"/> <input type="text" id="email" name="email" value="${person.email!}" class="form-control" placeholder="email"/> <span class="text-danger"><@spring.showErrors ""/></span> </div> <input type="submit" value="submit" class="btn btn-sm btn-primary"/></form>注:一定要先使用 <@spring.bind "person.username"/> 将字段绑定好,下面再使用 <@spring.showErrors ""/> 来取出来错误信息
参考
https://spring.io/guides/gs/validating-form-input/
总结
以上所述是小编给大家介绍的spring boot里增加表单验证hibernate-validator并在freemarker模板里显示错误信息(推荐),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
首先说下原理,表单验证使用validate验证器进行验证,如果表单验证不通过,将表单数据和错误信息闪存到session中去,然后再到表单中进行展示。1.验证器规
本文实例介绍了jQueryValidate表单验证,主要是利用jquery.metadata.js将校验规则直接写在class属性里面并定义错误信息的提示,分享
在我看来,警告框只用在浏览器不支持其他显示错误信息的办法的时候。W3C建议我们在表单项的附近显示错误信息。这是一种很好的办法,所以我们只在浏览器不支持这种高级的
springboot2.3之后,hibernate-validator依赖缺失今天在写项目的时候,发现@Blank注解没有了,检查了一下,发现老版本spring
当Android开发处理错误信息时,经常会以Dialog的形式显示错误信息,但是每次都new一个Dialog,很麻烦,也增加程序的开销,所以今天就分享一种自定义