精品熟女碰碰人人a久久,多姿,欧美欧美a v日韩中文字幕,日本福利片秋霞国产午夜,欧美成人禁片在线观看

Spring MVC+ajax進行信息驗證的方法

本文是一個ajax結合spring mvc使用的入門,首先我們來了解一下什么是ajax

ajax 不是新的編程語言,而是一種使用現有標準的新方法。ajax 最大的優點是在不重新加載整個頁面的情況下,可以與服務器交換數據并更新部分網頁內容。所以ajax對于提升用戶體驗十分重要

xmlhttprequest 是 ajax 的基礎。

主要的方法有兩種:

var xmlhttp=new xmlhttprequest();
xmlhttp.open(method,url,async)
xmlhttp.send();

   open方法里面的參數中,method代表請求的類型(get/post), url 代表要要請求的資源的位置,async代表是否要啟動異步請求,這個值一般都填true,因為這樣更快,不會因為服務端的響應慢而導致程序掛起

  send方法當然就是發起請求的動作啦

  這里需要注意:如果需要像 html 表單那樣 post 數據,請使用 setrequestheader() 來添加 http 頭。然后在 send() 方法中規定你希望發送的數據:

xmlhttp.open("post","url",true);
xmlhttp.setrequestheader("content-type","application/x-www-form-urlencoded");  //這一條非常重要,也非常有用
xmlhttp.send("fname=henry&lname=ford");

  上面代碼中的第2行,指明了發送的數據類型,其實一般我們用來指定發送的類型常用值是json類型,也就是"application/json",為什么常用json類型呢?你想想,當我們要發送多個值的時候,如果一個一個參數的去組織,那將是多么麻煩呀,而且服務端拿到數據后,還要我們一個一個的將數據從request.parameter里面拿出來,非常的浪費時間,所以,利用json,可以將數據先寫成json格式,再傳到后端,后端會自動解析,自動將數據填入對應的pojo,非常方便,

但是要做到這些,我們需要以下配置:

(1)設置content-type 為 "application/json" ,目的是告訴服務端傳過來的是json

(2)用json.stringify將數據轉換成json字符串再傳送

(3)服務端controller需要在方法的參數前用@requestbody,這樣服務端就會調用相應的解析器,將請求解析

  到這里我們一個完整的請求就完成啦!看完了請求,接下來我們再看響應,ajax接受響應的函數如下:

xmlhttp.onreadystatechange=function()  //自動調用
 {
  if (xmlhttp.readystate==4 && xmlhttp.status==200)
  {
   xmldoc=xmlhttp.responsexml; //獲得值
  }
 }

  ajax在接收到響應之后,會自動調用 onreadystatechange方法,然后通過responsexml獲取返回值,那么我們就會遇到一個問題:在spring mvc中,返回值會寫到modelandview中,然后查找到視圖,將數據渲染到視圖中,不能達到我們要的效果,即返回數據而不指定視圖,所以我們要用到@responsebody

   聲明@requestbody后,返回值如果是字符串則直接將字符串寫到客戶端,假如是一個對象,此時會將對象轉化為json串然后寫到客戶端。這里需要注意的是,如果返回對象,按utf-8編碼。如果返回string,默認按iso8859-1編碼,頁面可能出現亂碼。因此在注解中我們可以手動修改編碼格式,例如@requestmapping(value="/cat/query",produces="text/html;charset=utf-8"),前面是請求的路徑,后面是編碼格式。在客戶端,獲得json字符串以后,可以利用json.parse()將響應轉換為json對象,方便使用

一個實例demo:

 表單如下:

<form role="form" action="usercontroller/insert.do">
  <div class="form-group">
    <label for="exampleinputemail1">用戶名</label><input name="username" type="text" class="form-control" id="exampleinputemail1"
                             onblur="check(this)"/>
    <h5 style="color:red" id = "usernameinfo"></h4>
  </div>

  <div class="form-group">
    <label for="exampleinputpassword1">密碼</label><input name="password" type="password" class="form-control" id="exampleinputpassword1"
                              onblur="check(this)"/>
    <h5 style="color:red" id="passinfo"></h4>
  </div>
  <div class="form-group">
    <label for="exampleinputpassword1">確認密碼</label><input name="repassword" type="password" class="form-control" id="exampleinputpassword2"
                               onblur="check(this)"/>
    <h5 style="color:red" id="repassinfo"></label>
  </div>
  <button type="submit" class="btn btn-success btn-lg btn-block">提交</button>
</form>

 表單通過失去焦點的onblur觸發器觸發檢查的 js 代碼 check()

var check = function(info){
  if (info.name=="username"){
    var username = document.getelementbyid("exampleinputemail1").value.trim();
    if (username=="") {
      document.getelementbyid("usernameinfo").innerhtml = "用戶名不能為空";
    }else{
      loadxmldoc(); //執行ajax檢查
    }
/////分割線////////////////////////////////分割線/////////////////////////////////////////分割線
  }else if (info.name=="password"){
      var pass=document.getelementbyid("exampleinputpassword1").value.trim();
      if (pass==""){
        document.getelementbyid("passinfo").innerhtml="密碼不能為空";
      }else{
        document.getelementbyid("passinfo").innerhtml="";
      }
  }else{
    var value1=document.getelementbyid("exampleinputpassword2").value;
    var value2=document.getelementbyid("exampleinputpassword1").value;
    if (value1!=value2){
      document.getelementbyid("repassinfo").innerhtml="前后密碼不一致";
    }else{
      document.getelementbyid("repassinfo").innerhtml="";
    }
  }
}

上面的代碼差不多相同,所以只用看分割線上的就差不多了,分割線上面的是先用本地js檢測用戶輸入是否為空,然后若不為空,則執行ajax代碼,檢查賬號是否已經被占用,ajax代碼如下:

var loadxmldoc=function() {
  var xmlhttp=new xmlhttprequest();
  xmlhttp.onreadystatechange=function()
  {
    if (xmlhttp.readystate==4 && xmlhttp.status==200)
    {
      var text=xmlhttp.responsetext;
      document.getelementbyid("usernameinfo").innerhtml=text; //設置反饋信息
    }
  }
  var name = document.getelementbyid("exampleinputemail1").value;  //獲取用戶輸入
  xmlhttp.open("get","usercontroller/checkinfo.do?username="+name,true);  //構造請求
  xmlhttp.send();                           //發送
}

最后看看controller的代碼:

  @requestmapping(value="/checkinfo",produces={"text/html;charset=utf-8;"})  //設置編碼
  @responsebody                                //設置響應轉換為json
  public string check(httpservletrequest requst) {
    string username = requst.getparameter("username");
    system.out.println(username);
    integer id = userservice.check(username);    //檢查賬號是否已經存在
    if (id!=null) { 9       return "賬號已經存在";
    }else {
      return "";
    }
  }

成果展示:

利用js提醒密碼不能為空

                           

利用ajax檢測賬號是否重復,以及利用js檢測前后密碼是否一致

總結

以上所述是小編給大家介紹的spring mvc+ajax進行信息驗證的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對碩編程網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

相關文章