1. 程式人生 > >JSR303表單資料後臺校驗

JSR303表單資料後臺校驗

一、引入相關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方法
}