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

您的位置:首頁技術(shù)文章
文章詳情頁

Spring MVC+ajax進(jìn)行信息驗(yàn)證的方法

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

本文是一個(gè)ajax結(jié)合Spring MVC使用的入門,首先我們來了解一下什么是Ajax

AJAX 不是新的編程語言,而是一種使用現(xiàn)有標(biāo)準(zhǔn)的新方法。AJAX 最大的優(yōu)點(diǎn)是在不重新加載整個(gè)頁面的情況下,可以與服務(wù)器交換數(shù)據(jù)并更新部分網(wǎng)頁內(nèi)容。所以ajax對于提升用戶體驗(yàn)十分重要

XMLHttpRequest 是 AJAX 的基礎(chǔ)。

主要的方法有兩種:

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

  open方法里面的參數(shù)中,method代表請求的類型(GET/POST), url 代表要要請求的資源的位置,async代表是否要啟動(dòng)異步請求,這個(gè)值一般都填true,因?yàn)檫@樣更快,不會(huì)因?yàn)榉?wù)端的響應(yīng)慢而導(dǎo)致程序掛起

  send方法當(dāng)然就是發(fā)起請求的動(dòng)作啦

  這里需要注意:如果需要像 HTML 表單那樣 POST 數(shù)據(jù),請使用 setRequestHeader() 來添加 HTTP 頭。然后在 send() 方法中規(guī)定你希望發(fā)送的數(shù)據(jù):

xmlhttp.open("POST","url",true);xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");  //這一條非常重要,也非常有用xmlhttp.send("fname=Henry&lname=Ford");

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

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

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

(2)用JSON.stringify將數(shù)據(jù)轉(zhuǎn)換成JSON字符串再傳送

(3)服務(wù)端Controller需要在方法的參數(shù)前用@requestBody,這樣服務(wù)端就會(huì)調(diào)用相應(yīng)的解析器,將請求解析

  到這里我們一個(gè)完整的請求就完成啦!看完了請求,接下來我們再看響應(yīng),ajax接受響應(yīng)的函數(shù)如下:

xmlhttp.onreadystatechange=function()  //自動(dòng)調(diào)用 {  if (xmlhttp.readyState==4 && xmlhttp.status==200)  {   xmlDoc=xmlhttp.responseXML; //獲得值  } }

  Ajax在接收到響應(yīng)之后,會(huì)自動(dòng)調(diào)用 onreadystatechange方法,然后通過responseXML獲取返回值,那么我們就會(huì)遇到一個(gè)問題:在Spring MVC中,返回值會(huì)寫到ModelAndView中,然后查找到視圖,將數(shù)據(jù)渲染到視圖中,不能達(dá)到我們要的效果,即返回?cái)?shù)據(jù)而不指定視圖,所以我們要用到@responseBody

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

一個(gè)實(shí)例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">確認(rèn)密碼</label><input name="repassword" type="password" id="exampleInputPassword2"       onblur="check(this)"/>    <h5 id="repassInfo"></label>  </div>  <button type="submit">提交</button></form>

表單通過失去焦點(diǎn)的onblur觸發(fā)器觸發(fā)檢查的 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(); //執(zhí)行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檢測用戶輸入是否為空,然后若不為空,則執(zhí)行Ajax代碼,檢查賬號(hào)是否已經(jīng)被占用,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; //設(shè)置反饋信息    }  }  var name = document.getElementById("exampleInputEmail1").value;  //獲取用戶輸入  xmlhttp.open("GET","userController/checkInfo.do?username="+name,true);  //構(gòu)造請求  xmlhttp.send();   //發(fā)送}

最后看看Controller的代碼:

  @RequestMapping(value="/checkInfo",produces={"text/html;charset=utf-8;"})  //設(shè)置編碼  @ResponseBody//設(shè)置響應(yīng)轉(zhuǎn)換為JSON  public String check(HttpServletRequest requst) {    String username = requst.getParameter("username");    System.out.println(username);    Integer id = userService.check(username);    //檢查賬號(hào)是否已經(jīng)存在    if (id!=null) { 9       return "賬號(hào)已經(jīng)存在";    }else {      return "";    }  }

成果展示:

利用js提醒密碼不能為空

                          

利用ajax檢測賬號(hào)是否重復(fù),以及利用JS檢測前后密碼是否一致

總結(jié)

以上所述是小編給大家介紹的Spring MVC+ajax進(jìn)行信息驗(yàn)證的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

標(biāo)簽: Ajax
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
激情综合五月| 日韩午夜免费| 不卡在线一区二区| 欧美日韩1区2区3区| 国产精品麻豆久久| 亚洲伊人精品酒店| 91成人精品| 国产精品久久久免费| 99热精品在线| 婷婷视频一区二区三区| 偷拍欧美精品| 国产视频一区二| 久久一区二区三区电影| 爽好久久久欧美精品| 麻豆国产精品一区二区三区| 日韩一区二区三区在线免费观看| 香蕉久久久久久久av网站| 美女高潮久久久| 亚洲涩涩av| 亚洲天堂成人| 久久一区欧美| 国产精品社区| 国产精品久av福利在线观看| 你懂的亚洲视频| 国产精品普通话对白| 国产91在线精品| 久久国内精品| 欧美日韩尤物久久| 欧产日产国产精品视频| 精品国模一区二区三区| 999国产精品视频| 久久中文字幕av| 国产精品视频一区二区三区四蜜臂| 伊人影院久久| 综合激情网...| 伊人久久av| 91精品一区国产高清在线gif| 日韩精品视频在线看| 国产精品99一区二区三| 欧美一区二区三区久久精品| 日本电影久久久| 97国产精品| 欧美一区影院| 亚洲欧美日韩视频二区| 午夜天堂精品久久久久| 伊人www22综合色| 亚洲精品一区三区三区在线观看| 久久精品动漫| 久久精品五月| 亚洲69av| 在线日韩成人| 国精品产品一区| 夜夜嗨网站十八久久| 九色porny丨国产首页在线| 国产午夜久久| 成人久久一区| 久久99国产精品视频| 亚州av乱码久久精品蜜桃| 国产二区精品| 欧美精品观看| 91精品精品| 麻豆精品蜜桃视频网站| 日本亚洲视频| 亚洲欧洲专区| 首页国产精品| 日本在线精品| 国内精品麻豆美女在线播放视频| 三级一区在线视频先锋| 精品中国亚洲| 久久久久久美女精品| 亚洲在线国产日韩欧美| 国产视频亚洲| 国产精品社区| 中文在线免费视频| 日韩视频一二区| 免费人成在线不卡| 久久久免费人体| 88久久精品| 日韩欧美久久| 日韩欧美一区二区三区免费观看| 精品三级在线观看视频| 欧美不卡在线| 久久精品青草| 午夜av一区| 精品视频在线观看网站| 国产精品亚洲综合在线观看| 美美哒免费高清在线观看视频一区二区| 日本精品久久| 国产精品videosex极品| 日韩天堂av| 国产一区二区三区不卡视频网站| 久久精品国产在热久久| 韩日一区二区三区| 秋霞影视一区二区三区| 欧美+亚洲+精品+三区| 久久婷婷av| 亚洲精品动态| 国产精品欧美在线观看| 欧美国产中文高清| 久久影院一区| 激情五月综合网| 国产剧情一区二区在线观看| 午夜av一区| 久久男人av资源站| 蜜臀av亚洲一区中文字幕| 亚洲欧洲av| 久久高清精品| 图片区亚洲欧美小说区| 欧美 日韩 国产一区二区在线视频| 欧美在线亚洲综合一区| 亚洲激情久久| 中文字幕在线视频久| 久久夜夜操妹子| 亚洲国产欧美日本视频| 亚洲天堂黄色| 免费观看不卡av| 日本电影久久久| 秋霞影院一区二区三区| 国产精品日本一区二区三区在线 | 久久精品国语| 日本麻豆一区二区三区视频| 秋霞影视一区二区三区| 久久精品电影| 亚洲天堂一区二区| 日本a级不卡| 国产一区清纯| 丝瓜av网站精品一区二区| 国产欧美日韩亚洲一区二区三区| 给我免费播放日韩视频| 亚洲日本久久| 中国女人久久久| 热三久草你在线| 精品视频国产| 国产精品乱战久久久| 久久久水蜜桃av免费网站| 欧美日韩国产传媒| 国产一区丝袜| 麻豆精品蜜桃视频网站| 亲子伦视频一区二区三区| 国产在线日韩精品| 日韩国产精品久久久久久亚洲| 精品一区三区| 国产精品欧美大片| 在线亚洲成人| 国产+成+人+亚洲欧洲在线| 欧美日韩亚洲一区| 亚洲香蕉视频| 宅男噜噜噜66国产日韩在线观看| 欧美日韩在线网站| 成人精品国产亚洲| 在线一区视频观看| 天堂√8在线中文| 国产专区精品| 青青草伊人久久| 欧美精品导航| 久久a爱视频| 伊人久久大香伊蕉在人线观看热v| 国产精品mm| 九九精品调教| 四虎精品永久免费| 高清精品久久| 日韩成人一级| 国产精品xxx在线观看| 午夜久久av| 欧美一级精品| 亚洲精品免费观看| 久久99影视| 免费人成在线不卡| 国产欧美日韩精品高清二区综合区 | 美女精品一区二区| 成人久久久久| 日本在线成人| 日韩高清中文字幕一区二区| 一区二区三区国产盗摄| 91综合网人人| 日本午夜精品一区二区三区电影| 日韩精品不卡一区二区| 国产一区成人| 噜噜噜久久亚洲精品国产品小说| 国产精品v日韩精品v欧美精品网站| 久久久成人网| 国产精品白丝久久av网站| 一区在线免费观看| a国产在线视频| 国产日韩欧美在线播放不卡| 欧美日韩精品一本二本三本| 美腿丝袜在线亚洲一区| 视频一区二区三区中文字幕| 999久久久91| 日韩国产欧美一区二区| 国产精品1luya在线播放| 亚洲精品亚洲人成在线观看| 激情五月综合| 在线日韩一区| 国产一区日韩一区| 樱桃视频成人在线观看| 国产h片在线观看| 国产成人精品999在线观看| 久久国际精品| 国产精品毛片视频|