JSR303表單資料後臺校驗
阿新 • • 發佈:2019-01-07
一、引入相關jar包
<!-- 支援JSR303校驗 --> <!-- https://mvnrepository.com/artifact/org.hibernate/hibernate-validator --> <dependency> <groupId>org.hibernate</groupId> <artifactId>hibernate-validator</artifactId> <version>5.4.2.Final</version> </dependency>
二、修改javabean
public class Employee { private Integer empId; @Pattern(regexp="(^[a-zA-Z0-9_-]{6,16}$)|(^[\\u2E80-\\u9FFF]{2,5})",message="使用者名稱必須是2-5位中文或者6-16位英文和數字的組合") private String empName; private String gender; @Pattern(regexp="^([a-z0-9_\\.-]+)@([\\da-z\\.-]+)\\.([a-z\\.]{2,6})$",message="郵箱格式不正確") private String email; private Integer dId; }
注:1、其中get、set方法省略
2、正則表示式驗證和js有些區別,凡是\前面都要再加一個\
三、修改Controller
/** * 員工儲存 * 1.支援JSR303校驗 * 2.匯入Hibernate-Validator * * @return */ @RequestMapping(value="/emp",method=RequestMethod.POST) @ResponseBody public Msg saveEmp(@Valid Employee employee,BindingResult result) { if (result.hasErrors()) { //校驗失敗應該返回失敗,在模態框中顯示失敗提示資訊 //封裝錯誤資訊 Map<String, Object> map = new HashMap(); List<FieldError> errors = result.getFieldErrors(); for (FieldError fieldError : errors) { System.out.println("錯誤的欄位名:"+fieldError.getField()); System.out.println("錯誤的資訊:"+fieldError.getDefaultMessage()); map.put(fieldError.getField(), fieldError.getDefaultMessage()); } return Msg.fail().add("errorFiled", map); }else{ employeeService.saveEmp(employee); return Msg.success(); } }
注:1、新增@Valid註解
2、BindingResult返回驗證資訊
五、jsp頁面處理
$.ajax({
url:"${APP_PATH}/emp",
type:"POST",
data:$("#empAddModal form").serialize(),
success:function(result){
if(result.code == 100){
//員工儲存成功;
//來到最後一頁,顯示剛才儲存的資料
//傳送ajax請求顯示最後一頁資料即可
to_page(totalRecord);
}else{
//顯示失敗資訊
//console.log(result);
//有哪個欄位的錯誤資訊就顯示哪個欄位的;
if(undefined != result.extend.errorFields.email){
//顯示郵箱錯誤資訊
show_validate_msg("#email_add_input", "error", result.extend.errorFields.email);
}
if(undefined != result.extend.errorFields.empName){
//顯示員工名字的錯誤資訊
show_validate_msg("#empName_add_input", "error", result.extend.errorFields.empName);
}
}
}
});
六、附Msg錯誤處理類
public class Msg {
//狀態碼:100-成功;200-失敗
private int code;
//提示資訊
private String msg;
//使用者要返回給瀏覽器的資料
private Map<String, Object> extend = new HashMap<String,Object>();
//請求成功方法
public static Msg success() {
Msg result = new Msg();
result.setCode(100);
result.setMsg("處理成功");
return result;
}
//請求失敗方法
public static Msg fail() {
Msg result = new Msg();
result.setCode(200);
result.setMsg("處理失敗");
return result;
}
//新增可以鏈式繫結返回資料的方法
public Msg add(String key,Object value) {
this.getExtend().put(key, value);
return this;
}
//get&set方法
}