日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:860日期:2022-06-11 18:06:02

本文是一個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>    <label for="exampleInputEmail1">用戶名</label><input name="username" type="text" id="exampleInputEmail1"     onblur="check(this)"/>    <h5 id = "usernameInfo"></h4>  </div>  <div>    <label for="exampleInputPassword1">密碼</label><input name="password" type="password" id="exampleInputPassword1"      onblur="check(this)"/>    <h5 id="passInfo"></h4>  </div>  <div>    <label for="exampleInputPassword1">確認密碼</label><input name="repassword" type="password" id="exampleInputPassword2"       onblur="check(this)"/>    <h5 id="repassInfo"></label>  </div>  <button type="submit">提交</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進行信息驗證的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

標簽: Ajax
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩精品1区| 久久av日韩| 成人午夜网址| 日韩国产一区| 日韩欧美中文字幕电影 | 国产精品观看| 亚洲精品123区| 日韩免费久久| 91午夜精品| 蜜臀久久99精品久久久画质超高清 | 日韩欧乱色一区二区三区在线| 麻豆国产精品视频| 日韩av一二三| 在线亚洲精品| 免费视频亚洲| 国产欧美成人| 日韩久久一区| 亚洲三级观看| 亚洲免费影院| 久久国产电影| 在线观看亚洲精品福利片| 国产一区福利| 久久超碰99| 美女精品一区二区| 欧美国产另类| 视频一区视频二区中文字幕| 天堂网av成人| 97在线精品| 久久精品国产亚洲夜色av网站| 久久青草久久| 欧美日韩国产在线观看网站| 五月天综合网站| 亚洲区第一页| 日韩av不卡一区二区| 国产精品久久久久久久久久久久久久久 | 成人在线视频中文字幕| 精品久久97| 久久九九精品| 日韩在线观看一区二区| 黑丝一区二区三区| 电影91久久久| 亚洲综合色婷婷在线观看| 日本不良网站在线观看| 婷婷成人综合| 亚洲激情社区| 亚洲女同av| 国产99精品一区| 蜜桃av一区二区在线观看| 一区二区日韩免费看| 久久av网址| 日韩网站在线| 欧美aaaaaa午夜精品| 四虎884aa成人精品最新| 欧美亚洲国产精品久久| 黄色不卡一区| 日韩精品久久久久久久软件91| 美女久久精品| 黄色成人精品网站| 欧美国产精品| 鲁大师影院一区二区三区| 国产精品毛片aⅴ一区二区三区| 99视频精品全部免费在线视频| 欧美欧美黄在线二区| 欧美一区二区三区高清视频| 午夜久久av | 久久精品国产免费| 久久先锋影音| 久久男人av资源站| 亚洲一区二区免费看| 国产一区一一区高清不卡| 久久高清免费观看| 亚洲成人va| 日韩在线二区| 国产一区二区三区探花| 亚洲免费中文| 久久先锋影音| 99久久激情| 久久精品国产一区二区| 香蕉国产精品| 精品日韩毛片| 天堂日韩电影| 亚洲福利久久| 99在线精品免费视频九九视| 夜鲁夜鲁夜鲁视频在线播放| 成人免费一区| 91视频精品| 黑人精品一区| 亚洲一区二区三区中文字幕在线观看| 久久字幕精品一区| 麻豆国产精品一区二区三区| 精品一区二区三区中文字幕视频| 精品国产亚洲日本| 亚洲黑丝一区二区| 九一精品国产| 日本vs亚洲vs韩国一区三区二区| 日韩不卡手机在线v区| 精品九九在线| 亚洲美洲欧洲综合国产一区| 婷婷视频一区二区三区| 麻豆成人在线观看| 好看不卡的中文字幕| 日韩黄色免费网站| 中文字幕一区久| 免费日本视频一区| 日韩欧美一区二区三区在线观看| 美女一区网站| 激情久久一区二区| 精品视频国产| 乱一区二区av| 国产精品手机在线播放| 中文一区二区| 自由日本语亚洲人高潮| 免费在线视频一区| 日韩一区二区中文| 国产精品v一区二区三区| 欧美日一区二区在线观看| 久久成人亚洲| 黑丝一区二区三区| 精品国产成人| 亚洲欧美久久| 影院欧美亚洲| 午夜在线观看免费一区| 日韩精品视频一区二区三区| 国产一区丝袜| 视频小说一区二区| 久久精品123| 精品国产欧美| www成人在线视频| 妖精视频成人观看www| 日韩激情一区二区| 久久国产亚洲| 日韩福利一区| 精品一区毛片| 日本不卡一二三区黄网| 欧美国产另类| 久久亚洲精品中文字幕蜜潮电影| 日韩欧美另类中文字幕| 日韩高清成人在线| 在线精品一区二区| 精品久久久中文字幕| 亚洲一区黄色| 精精国产xxxx视频在线野外| 在线综合亚洲| 亚洲1区在线| 精品视频高潮| 蜜桃久久av一区| 激情久久久久久久| 成人午夜毛片| 亚洲欧美日韩精品一区二区 | 婷婷五月色综合香五月| 91精品国产经典在线观看| 免费在线观看不卡| 久久性天堂网| 蜜臀国产一区| 日韩1区2区3区| 国产中文字幕一区二区三区| 欧美a级片一区| 日本久久黄色| 国产精品精品国产一区二区| 日本精品一区二区三区在线观看视频| 成人黄色av| 久久99青青| 国产精品一国产精品k频道56| 国产欧美一区二区色老头| 日韩一级网站| 麻豆一区二区99久久久久| 婷婷视频一区二区三区| 精品网站aaa| 你懂的国产精品| 欧美日韩午夜| 美女黄网久久| 欧美成a人免费观看久久| 日本国产欧美| 国产调教精品| 久久av电影| 久久女人天堂| 日韩精品影视| 婷婷激情一区| 99精品网站| 六月婷婷综合| 国产精品99免费看| 日本在线视频一区二区| 国产日韩高清一区二区三区在线 | 日韩不卡一区二区三区 | 好吊日精品视频| 自由日本语亚洲人高潮| 国产一区二区三区不卡视频网站 | 亚洲精品乱码久久久久久蜜桃麻豆 | 久久久夜精品| 深夜福利亚洲| 少妇精品导航| 亚洲一区二区小说| 日韩国产欧美在线播放| 日韩二区三区在线观看| 日韩精品dvd| 综合激情视频| 色综合www| 久久伊人久久| 日韩一区二区三区免费播放| 狠狠操综合网|