亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

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

2024-09-01 08:31:18
字體:
來源:轉載
供稿:網友

本文是一個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進行信息驗證的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
免费91麻豆精品国产自产在线观看| 欧美色xxxx| 日韩中文字幕免费看| 国产亚洲精品一区二555| 91精品在线国产| 国产精品欧美风情| 夜夜躁日日躁狠狠久久88av| 亚洲国产精品yw在线观看| 国产精品羞羞答答| 精品中文视频在线| 久久99精品久久久久久琪琪| 欧美乱大交xxxxx| 色多多国产成人永久免费网站| 日韩精品在线免费观看视频| 91久久在线观看| 免费91麻豆精品国产自产在线观看| 日韩精品在线私人| 日日狠狠久久偷偷四色综合免费| 国产69精品久久久| 精品久久久香蕉免费精品视频| 26uuu日韩精品一区二区| 在线看欧美日韩| 欧美日本啪啪无遮挡网站| 亚洲美女在线观看| 国语自产精品视频在线看抢先版图片| 日韩女在线观看| 亚洲综合一区二区不卡| 97av在线视频免费播放| 午夜精品一区二区三区av| 色噜噜国产精品视频一区二区| 国产精品主播视频| 国产成人一区二区| 国产精品久久久久久久app| 久久久影视精品| 中文字幕精品—区二区| 亚洲人成电影在线播放| 日韩精品在线影院| 亚洲国产私拍精品国模在线观看| 日韩av黄色在线观看| 欧美激情日韩图片| 一区二区三区无码高清视频| 国产精品一区二区久久久久| 欧美极品少妇与黑人| 国产精品丝袜白浆摸在线| 国产精品久久久久久婷婷天堂| 亚洲国产第一页| 色婷婷**av毛片一区| 国产精品福利网站| 欧美在线观看网址综合| 中文字幕国产日韩| 91久久国产婷婷一区二区| 久久久久久这里只有精品| 国产日韩精品在线观看| 日本欧美一级片| 亚洲精品福利在线观看| 欧美激情视频在线观看| 亚洲a在线观看| 亚洲精品美女久久| 国产精品欧美日韩久久| 亚洲美女性视频| 都市激情亚洲色图| 欧美激情视频一区| 亚洲欧美国产日韩天堂区| 欧美精品免费在线观看| 久久久精品999| 亚洲图片欧洲图片av| 日韩激情视频在线播放| 亚洲18私人小影院| 在线播放亚洲激情| 中文字幕亚洲一区二区三区| 欧美乱大交xxxxx另类电影| 国产精品美女主播在线观看纯欲| 97精品国产97久久久久久免费| 亚洲欧美中文日韩在线v日本| 中文字幕久精品免费视频| 精品久久国产精品| 超碰精品一区二区三区乱码| 45www国产精品网站| 欧美成人亚洲成人日韩成人| 欧美人与性动交| 国产精品日韩av| 成人久久久久久久| 国产欧洲精品视频| 精品呦交小u女在线| 97色在线播放视频| 92版电视剧仙鹤神针在线观看| 欧美日韩国产精品一区二区不卡中文| 亚洲欧洲午夜一线一品| 动漫精品一区二区| www亚洲精品| 欧美一区二区大胆人体摄影专业网站| 久久久欧美一区二区| 日韩欧美在线第一页| 欧美刺激性大交免费视频| 91夜夜揉人人捏人人添红杏| 国产精品偷伦免费视频观看的| 久久亚洲精品小早川怜子66| 久久久久久久久久久久久久久久久久av| 日产精品99久久久久久| 久久久久久尹人网香蕉| 九九精品在线观看| 欧美精品videossex性护士| 精品久久久久久久大神国产| 欧洲成人性视频| 在线观看中文字幕亚洲| 亚洲第一精品久久忘忧草社区| 亚洲欧美另类国产| 亚洲精品白浆高清久久久久久| 91午夜在线播放| 91国偷自产一区二区三区的观看方式| 亚洲深夜福利网站| 欧美一区亚洲一区| 亚洲在线观看视频网站| 欧美精品精品精品精品免费| 久久久久久国产精品| 国产精品久久99久久| 在线成人激情黄色| 91中文字幕一区| 黑人与娇小精品av专区| 色偷偷av亚洲男人的天堂| 国外色69视频在线观看| 成人激情视频在线观看| 国产91九色视频| 欧美成人久久久| 8x海外华人永久免费日韩内陆视频| 亚洲乱码一区av黑人高潮| 亚洲欧美日韩另类| 成人精品在线观看| 精品视频—区二区三区免费| 国产成人精品网站| 精品亚洲夜色av98在线观看| 国产成人+综合亚洲+天堂| 成年人精品视频| 欧美高清无遮挡| 国产精品99久久久久久人| 国内精品伊人久久| 久久精品99久久香蕉国产色戒| 国产亚洲精品高潮| 国产精品99久久99久久久二8| 日韩欧美在线看| 亚洲精品国产精品国产自| 2018中文字幕一区二区三区| 国产v综合ⅴ日韩v欧美大片| 亚洲精品成人免费| 久久综合九色九九| 国内成人精品视频| 国产亚洲视频中文字幕视频| 欧美成人午夜激情视频| 国产精品久久久久久久av大片| 午夜精品在线观看| 国产+成+人+亚洲欧洲| 亚洲国产精品网站| 国产乱人伦真实精品视频| 日韩经典中文字幕| 国产精品极品美女在线观看免费| 国产精品爱久久久久久久| 亚洲图片欧美日产| 午夜精品久久久久久99热| 在线精品91av| 成人免费观看49www在线观看| 亚洲综合社区网| 国产欧美一区二区| 亚洲三级 欧美三级| 中文字幕亚洲一区二区三区五十路|