校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Spring MVC+ajax進行信息驗證的方法

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

熱門標簽:提高電話機器人接通率 外呼系統api對接 銷售電銷機器人詐騙 福建微碼電話機器人 大學校門地圖標注 廣西智能外呼系統多少錢 荊州智能電銷機器人 平涼高德地圖標注商戶要收費嗎 地圖標注與公司業務關系

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

您可能感興趣的文章:
  • Ajax實現文件上傳功能(Spring MVC)
  • Springmvc完成ajax功能實例詳解
  • SpringMVC+Jquery實現Ajax功能
  • 解決SpringMVC接收不到ajaxPOST參數的問題
  • spring mvc利用ajax向controller傳遞對象的方法示例
  • 解決spring mvc 返回json數據到ajax報錯parseerror問題
  • Springmvc處理ajax請求并返回json數據

標簽:邯鄲 樂山 海南 內江 黔東 德陽 衡陽 婁底

巨人網絡通訊聲明:本文標題《Spring MVC+ajax進行信息驗證的方法》,本文關鍵詞  Spring,MVC+ajax,進行,信息,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Spring MVC+ajax進行信息驗證的方法》相關的同類信息!
  • 本頁收集關于Spring MVC+ajax進行信息驗證的方法的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    午夜婷婷国产麻豆精品| 国产呦萝稀缺另类资源| 亚洲一级电影视频| 国产在线麻豆精品观看| 337p亚洲精品色噜噜狠狠| 中文字幕一区二区三中文字幕| 国产成人精品影视| 精品久久久久久久人人人人传媒 | 欧美精品丝袜久久久中文字幕| 久久精品在这里| 国产suv精品一区二区883| 久久综合色综合88| 福利一区二区在线观看| 国产清纯白嫩初高生在线观看91 | 欧美xxxxx裸体时装秀| 蜜臀av性久久久久蜜臀aⅴ流畅 | 91精品国产91综合久久蜜臀| 亚洲乱码国产乱码精品精98午夜 | 亚洲免费电影在线| 在线欧美小视频| 亚洲自拍欧美精品| 在线观看日韩电影| 日韩精品一卡二卡三卡四卡无卡| 日韩视频在线观看一区二区| 老司机午夜精品| 国产精品毛片久久久久久| 色网站国产精品| 日韩成人一区二区三区在线观看| wwww国产精品欧美| 色悠久久久久综合欧美99| 亚洲自拍偷拍麻豆| 国产亚洲午夜高清国产拍精品| 国产白丝网站精品污在线入口| 欧美精品一区二区精品网| 成人一道本在线| 美国毛片一区二区| 日韩毛片精品高清免费| 制服丝袜日韩国产| 成人听书哪个软件好| 免费美女久久99| 亚洲色图色小说| 国产亚洲精品免费| 欧美变态凌虐bdsm| 欧美美女直播网站| 99久久综合国产精品| 国产盗摄视频一区二区三区| 亚洲成人先锋电影| 亚洲小说春色综合另类电影| 国产午夜亚洲精品理论片色戒| 在线成人免费观看| 欧美色图天堂网| 色婷婷狠狠综合| 美女久久久精品| 天堂久久久久va久久久久| 亚洲精品国产品国语在线app| 欧美国产日韩a欧美在线观看| 久久综合给合久久狠狠狠97色69| 69av一区二区三区| 5月丁香婷婷综合| 欧美日韩国产大片| 69堂国产成人免费视频| 91精品国产麻豆| 欧美一区中文字幕| 精品国产一区二区在线观看| 日韩一区二区麻豆国产| 欧美大片一区二区| 国产欧美一区二区精品久导航 | 3d动漫精品啪啪1区2区免费| 欧美日韩精品欧美日韩精品| 欧美日韩一区二区欧美激情| 欧美日精品一区视频| a级精品国产片在线观看| 国产一二精品视频| 99天天综合性| 制服视频三区第一页精品| 久久在线观看免费| 亚洲免费观看高清完整版在线观看熊 | 91一区二区三区在线播放| 欧美日韩久久一区二区| 日韩精品一区二区三区视频在线观看| 久久综合狠狠综合久久激情 | 午夜欧美在线一二页| 国产精品一区二区91| 911精品国产一区二区在线| 国产拍欧美日韩视频二区| 图片区小说区国产精品视频| 久久精品av麻豆的观看方式| 国产高清在线观看免费不卡| 色综合一个色综合| 国产日韩欧美精品电影三级在线| 一区二区日韩电影| 成人av在线一区二区三区| 欧美一区二区三区电影| 亚洲乱码一区二区三区在线观看| 日韩在线观看一区二区| 欧美性极品少妇| 亚洲综合色区另类av| 99久久免费国产| 国产精品你懂的在线| 高清av一区二区| 久久精品一区二区三区不卡牛牛| 亚洲午夜精品一区二区三区他趣| 不卡的av电影| 亚洲图片激情小说| av福利精品导航| 综合久久国产九一剧情麻豆| 高清成人在线观看| 中文字幕一区二区在线观看| jizzjizzjizz欧美| 国产亚洲精品精华液| 国产精品系列在线观看| 国产精品网曝门| av亚洲产国偷v产偷v自拍| 亚洲综合一二区| 欧美精品久久99久久在免费线 | 国产精品人成在线观看免费| 不卡视频在线观看| 一区二区视频在线看| 欧美精品vⅰdeose4hd| 日韩电影在线免费看| 欧美精品一区二区三| 99精品桃花视频在线观看| 一区二区三区资源| 日韩三级高清在线| 成人高清视频在线| 视频一区视频二区中文字幕| 欧美大尺度电影在线| 本田岬高潮一区二区三区| 国产女同互慰高潮91漫画| 91污在线观看| 精品在线播放免费| 亚洲妇女屁股眼交7| 日本一区二区高清| 欧美日韩精品福利| 色综合一区二区| 成人国产精品免费网站| 七七婷婷婷婷精品国产| 一区二区三国产精华液| 久久久久久久久久久99999| 欧美午夜寂寞影院| 99精品视频在线观看| 大桥未久av一区二区三区中文| 麻豆91在线播放免费| 亚洲一级电影视频| 亚洲福利国产精品| 亚洲欧美色综合| 国产精品久久777777| 久久久亚洲高清| 久久免费视频色| 久久综合久久综合亚洲| 精品国产乱码久久久久久牛牛 | 中文字幕在线一区二区三区| 欧美大肚乱孕交hd孕妇| 2024国产精品视频| 久久综合色之久久综合| 久久久国产午夜精品| 久久精品夜色噜噜亚洲aⅴ| 26uuu成人网一区二区三区| 日韩精品一区二区三区在线观看| 欧美精品aⅴ在线视频| 欧美一卡二卡三卡| www国产亚洲精品久久麻豆| 中文字幕乱码一区二区免费| 中文字幕一区免费在线观看| 悠悠色在线精品| 奇米777欧美一区二区| 国产一区二区免费视频| 99久久精品免费观看| 欧美视频一区二区三区在线观看 | 99久久伊人精品| 欧美亚洲愉拍一区二区| 欧美mv日韩mv国产网站app| 国产日本一区二区| 石原莉奈在线亚洲二区| 性欧美大战久久久久久久久| 老汉av免费一区二区三区| 国产99久久久国产精品潘金网站| 一本到一区二区三区| 日韩午夜精品视频| 一二三区精品视频| 国产一区二区毛片| 欧美区一区二区三区| 国产欧美日韩一区二区三区在线观看| 亚洲精品日韩一| 国产成人免费视| 91精品国产综合久久福利软件 | 欧美日韩国产一二三| 国产欧美日韩精品在线| 美国精品在线观看| 欧美中文字幕一区| 亚洲精品免费视频| 成人动漫一区二区三区| 久久色在线观看| 捆绑调教一区二区三区| 欧美精品久久一区二区三区| 一二三四区精品视频| 在线观看www91| 亚洲成人资源在线| 色香蕉成人二区免费| 亚洲欧美另类小说|