麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發(fā)設計 > 正文

SpringMVC學習系列-后記 結合SpringMVC和Hibernate-validator,根據(jù)后臺驗證規(guī)則自動生成前臺的js驗證代碼

2019-11-15 00:45:05
字體:
來源:轉載
供稿:網友
SPRingMVC學習系列-后記 結合SpringMVC和Hibernate-validator,根據(jù)后臺驗證規(guī)則自動生成前臺的js驗證代碼

在SpringMVC學習系列(6) 之 數(shù)據(jù)驗證中我們已經學習了如何結合Hibernate-validator進行后臺的數(shù)據(jù)合法性驗證,但是通常來說后臺驗證只是第二道保險,為了更好的用戶體驗會現(xiàn)在前端進行js驗證,驗證通過之后數(shù)據(jù)才能提交到后臺,那么我們不可避免的要在前端的頁面中寫對應的js驗證代碼。

但是這樣就需要進行一些很麻煩且重復的操作:

1.首先要保證前端和后臺的驗證規(guī)則要相同,避免出現(xiàn)前端驗證通過,提交后又出現(xiàn)驗證失敗的情況。

2.其次要保證前端和后臺的驗證規(guī)則要同步,即修改一邊的驗證規(guī)則后要修改另一邊對應的驗證規(guī)則。

3.要保證錯誤提示信息的一致和相應的國際化問題。(其實這個問題在js驗證代碼中提示錯誤信息的地方,綁定國際化信息可以解決,只是比較啰嗦。)

好吧~~~以上這些都不是主要原因,主要原因是我太懶了不想在每個頁面中再一個一個寫對應的js驗證代碼,那么如何才能讓后臺根據(jù)我們定義的模型驗證規(guī)則自動生成前端的js驗證代碼呢?

下面一步一步來:

首先我想像spring mvc的form標簽一樣<form:form modelAttribute="contentModel" method="post">,這樣指定一下就可以生成對應的前端代碼,簡潔優(yōu)雅,多爽!,那么我們就要先自定義taglib標簽。

1.添加一個類,這里就叫JsValidateTag,我是定義在com.demo.test包下面的。

2.在WebContent/WEB-INF目錄下面添加一個xml文件,我這里名稱叫test.tld內容如下:

<?xml version="1.0" encoding="UTF-8"?><taglib xmlns="http://java.sun.com/xml/ns/j2ee"        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"        xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd"        version="2.0">                <description>Test</description>        <tlib-version>1.0</tlib-version>        <short-name>test</short-name>        <uri>http://www.mytest.org/tags/test</uri>                <tag>            <description></description>            <name>jsValidate</name>            <tag-class>com.demo.test.JsValidateTag</tag-class>            <body-content>empty</body-content>            <attribute>                <description>Path to property for data binding</description>                <name>modelAttribute</name>                <required>true</required>                <rtexprvalue>true</rtexprvalue>            </attribute>        </tag>        </taglib>

上面的內容很簡單,就是定義了一個叫jsValidate的標簽,對應的類是com.demo.test.JsValidateTag就是我們之前新建的那個,然后有一個叫modelAttribute的參數(shù)。

3.接下來在我們新建的類里面實現(xiàn)具體的處理邏輯,代碼如下:

package com.demo.test;import java.lang.reflect.Field;import java.util.ArrayList;import java.util.HashMap;import java.util.Iterator;import java.util.List;import java.util.Map;import java.util.Map.Entry;import javax.servlet.jsp.JspException;import org.hibernate.validator.constraints.Email;import org.hibernate.validator.constraints.NotEmpty;import org.hibernate.validator.constraints.Range;import org.springframework.web.servlet.tags.form.AbstractFormTag;import org.springframework.web.servlet.tags.form.TagWriter;/** *  * 自動生成前臺js驗證代碼 * @author [email protected] * */@SuppressWarnings("serial")public class JsValidateTag extends AbstractFormTag {    @SuppressWarnings("unused")    private TagWriter tagWriter;    private String modelAttribute;    public void setModelAttribute(String modelAttribute) {        this.modelAttribute = modelAttribute;    }        public String getModelAttribute() throws JspException {        String resolvedModelAttribute = (String) evaluate("modelAttribute", this.modelAttribute);        return (resolvedModelAttribute != null ? resolvedModelAttribute : "");    }    @Override    protected int writeTagContent(TagWriter tagWriter) throws JspException {        Object model;        if(getRequestContext().getModel()!=null)            model=getRequestContext().getModel().get(getModelAttribute());        else            model=this.pageContext.getRequest().getAttribute(getModelAttribute());        if(model!=null){            Map<String, List<String[]>> fieldValidateMap=new HashMap<String, List<String[]>>();            try {                Field[] theFields=model.getClass().getDeclaredFields();                if(theFields!=null&& theFields.length>0){                    for(Field field : theFields){                        String fieldName=field.getName();                        List<String[]> fieldValidateList=new ArrayList<String[]>();                        NotEmpty notEmpty=field.getAnnotation(NotEmpty.class);                        if(notEmpty!=null){                            String messageName=notEmpty.message();                            fieldValidateList.add(new String[]{"required","true",getRequestContext().getMessage(messageName.substring(1, messageName.length()-1))});                        }                                                Email email=field.getAnnotation(Email.class);                        if(email!=null){                            String messageName=email.message();                            fieldValidateList.add(new String[]{"email","true",getRequestContext().getMessage(messageName.substring(1, messageName.length()-1))});                        }                                                Range range=field.getAnnotation(Range.class);                        if(range!=null){                            String messageName=range.message();                            fieldValidateList.add(new String[]{"range","["+range.min()+","+range.max()+"]",getRequestContext().getMessage(messageName.substring(1, messageName.length()-1))});                        }                                                                        if(fieldValidateList.size()>0){                            fieldValidateMap.put(fieldName, fieldValidateList);                        }                    }                }            }catch (SecurityException e1) {                e1.printStackTrace();            }                        if(fieldValidateMap.size()>0){                        StringBuilder rulesBuilder=new StringBuilder();                StringBuilder messagesBuilder=new StringBuilder();                                rulesBuilder.append("rules:{");                messagesBuilder.append("messages:{");                int i=0;                Iterator<Entry<String, List<String[]>>> iterator=fieldValidateMap.entrySet().iterator();                while(iterator.hasNext()){                    Entry<String, List<String[]>> entry=iterator.next();                    rulesBuilder.append(entry.getKey()).append(":{");                    messagesBuilder.append(entry.getKey()).append(":{");                                        int j=0;                    for(String[] array : entry.getValue()){                        rulesBuilder.append(array[0]).append(":").append(array[1]);                        messagesBuilder.append(array[0]).append(":/"").append(array[2]).append("/"");                        if(j<entry.getValue().size()-1){                            rulesBuilder.append(",");                            messagesBuilder.append(",");                        }                        j++;                    }                                        rulesBuilder.append("}");                    messagesBuilder.append("}");                    if(i<fieldValidateMap.size()-1){                        rulesBuilder.append(",");                        messagesBuilder.append(",");                    }                    i++;                }                                rulesBuilder.append("},");                messagesBuilder.append("}");                tagWriter.startTag("script");                tagWriter.writeAttribute("type", "text/Javascript");                tagWriter.appendValue("$(function() {");                tagWriter.appendValue("$(/"#");                tagWriter.appendValue(getModelAttribute());                tagWriter.appendValue("/").validate({");                //在失去焦點時驗證                tagWriter.appendValue("onfocusout:function(element){$(element).valid();},");                tagWriter.appendValue(rulesBuilder.toString());                tagWriter.appendValue(messagesBuilder.toString());                tagWriter.appendValue("});");                tagWriter.appendValue("});");                tagWriter.endTag(true);            }            }                this.tagWriter=tagWriter;        return EVAL_BODY_INCLUDE;    }        @Override    public void doFinally() {        super.doFinally();        this.tagWriter = null;    }}

4.接下來在頁面中引用我們自定義的標簽:

<%@ taglib prefix="test" uri="http://www.mytest.org/tags/test" %>

并指定模型名稱:

<test:jsValidate modelAttribute="contentModel"></test:jsValidate>

頁面整體內容如下:

<%@ page language="java" contentType="text/html; charset=UTF-8"    pageEncoding="UTF-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %><%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %><%@ taglib prefix="test" uri="http://www.mytest.org/tags/test" %><html><head>    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">    <title>Insert title here</title>    <script src="<c:url value='/js/jquery-1.10.2.min.js'/>" type="text/javascript"></script>    <script src="<c:url value='/js/jquery.validate.min.js'/>" type="text/javascript"></script></head><body>    <form:form modelAttribute="contentModel" method="post">                     <form:errors path="*"></form:errors><br/><br/>                    name:<form:input path="name" /><br/>        <form:errors path="name"></form:errors><br/>                        age:<form:input path="age" /><br/>        <form:errors path="age"></form:errors><br/>                email:<form:input path="email" /><br/>        <form:errors path="email"></form:errors><br/>        <input type="submit" value="Submit" />            </form:form>  </body><test:jsValidate modelAttribute="contentModel"></test:jsValidate></html>

好了運行測試看看效果吧:

啊哈哈哈哈哈~~~,已經生成好了,再也不用親自寫驗證規(guī)則了,懶癌病情又加重了~~~

注:以上的代碼只實現(xiàn)了@NotEmpty、@Range、@NotEmpty三個注解對應的js驗證規(guī)則,其它注解的js驗證規(guī)則在JsValidateTag類中添加相應的邏輯即可。

項目源碼下載:http://pan.baidu.com/s/1c0pVzFy

保留版權,如需轉載請注明出處…


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美一级黄色录相 | 日本xxxx视频 | 国产色视频免费 | 久久777国产线看观看精品 | 中文字幕在线免费观看电影 | 成人男女视频 | 久草在线视频免费播放 | 国产91丝袜在线播放 | 午夜精品小视频 | 欧美亚洲国产一区二区三区 | 久久成人国产精品 | 欧美a视频在线观看 | qyl在线视频精品免费观看 | 欧美黄 片免费观看 | av影院在线 | 欧美一区二区黄 | 一级免费大片 | 国产精品一区在线看 | 成人一级毛片 | 性欧美极品xxxx欧美一区二区 | 亚洲午夜天堂吃瓜在线 | 激情大乳女做爰办公室韩国 | 久草在线视频网 | 好吊一区二区三区 | 日韩精品a在线观看 | 国产精品久久久久久久久久电影 | 日韩999 | 日韩视频高清 | 日韩在线播放一区二区 | 一级做受大片免费视频 | 免费一级毛片在线播放视频 | 久久久久亚洲精品 | 欧美 日韩 国产 在线 | 亚洲欧美国产高清 | 久久久久久久99 | 精品国产一区二区三区四区在线 | 91精品国产综合久久久动漫日韩 | 精品国产99久久久久久宅男i | 一级黄色免费观看 | 国产精品999在线观看 | 欧美一级淫片免费视频1 |