电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

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

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

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

XMLHttpRequest 是 AJAX 的基礎(chǔ)。

主要的方法有兩種:

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

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

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

  這里需要注意:如果需要像 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ù)類型,其實一般我們用來指定發(fā)送的類型常用值是JSON類型,也就是"application/json",為什么常用JSON類型呢?你想想,當我們要發(fā)送多個值的時候,如果一個一個參數(shù)的去組織,那將是多么麻煩呀,而且服務(wù)端拿到數(shù)據(jù)后,還要我們一個一個的將數(shù)據(jù)從request.parameter里面拿出來,非常的浪費時間,所以,利用JSON,可以將數(shù)據(jù)先寫成JSON格式,再傳到后端,后端會自動解析,自動將數(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ù)端就會調(diào)用相應(yīng)的解析器,將請求解析

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

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

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

  聲明@requestBody后,返回值如果是字符串則直接將字符串寫到客戶端,假如是一個對象,此時會將對象轉(zhuǎn)化為JSON串然后寫到客戶端。這里需要注意的是,如果返回對象,按utf-8編碼。如果返回String,默認按iso8859-1編碼,頁面可能出現(xiàn)亂碼。因此在注解中我們可以手動修改編碼格式,例如@RequestMapping(value="/cat/query",produces="text/html;charset=utf-8"),前面是請求的路徑,后面是編碼格式。在客戶端,獲得JSON字符串以后,可以利用JSON.parse()將響應(yīng)轉(zhuǎn)換為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觸發(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代碼,檢查賬號是否已經(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);    //檢查賬號是否已經(jīng)存在    if (id!=null) { 9       return "賬號已經(jīng)存在";    }else {      return "";    }  }

成果展示:

利用js提醒密碼不能為空

                          

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

總結(jié)

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

標簽: Ajax
相關(guān)文章:
主站蜘蛛池模板: 扒渣机厂家_扒渣机价格_矿用扒渣机_铣挖机_撬毛台车_襄阳永力通扒渣机公司 | 背压阀|减压器|不锈钢减压器|减压阀|卫生级背压阀|单向阀|背压阀厂家-上海沃原自控阀门有限公司 本安接线盒-本安电路用接线盒-本安分线盒-矿用电话接线盒-JHH生产厂家-宁波龙亿电子科技有限公司 | 沈阳网站建设_沈阳网站制作_沈阳网页设计-做网站就找示剑新零售 沈阳缠绕膜价格_沈阳拉伸膜厂家_沈阳缠绕膜厂家直销 | 硫化罐-电加热蒸汽硫化罐生产厂家-山东鑫泰鑫智能装备有限公司 | 药品冷藏箱厂家_低温冰箱_洁净工作台-济南欧莱博电子商务有限公司官网 | 广州工业氧气-工业氩气-工业氮气-二氧化碳-广州市番禺区得力气体经营部 | 亿诺千企网-企业核心产品贸易| 附着力促进剂-尼龙处理剂-PP处理剂-金属附着力处理剂-东莞市炅盛塑胶科技有限公司 | 真空冷冻干燥机_国产冻干机_冷冻干燥机_北京四环冻干 | 气弹簧定制-气动杆-可控气弹簧-不锈钢阻尼器-工业气弹簧-可调节气弹簧厂家-常州巨腾气弹簧供应商 | 酒店品牌设计-酒店vi设计-酒店标识设计【国际级】VI策划公司 | 北京租车牌|京牌指标租赁|小客车指标出租 | 石英粉,滑石粉厂家,山东滑石粉-莱州市向阳滑石粉有限公司 | 袋式过滤器,自清洗过滤器,保安过滤器,篮式过滤器,气体过滤器,全自动过滤器,反冲洗过滤器,管道过滤器,无锡驰业环保科技有限公司 | 抓斗式清污机|螺杆式|卷扬式启闭机|底轴驱动钢坝|污水处理闸门-方源水利机械 | 武汉森源蓝天环境科技工程有限公司-为环境污染治理提供协同解决方案 | 驾驶人在线_专业学车门户网站 | 间苯二酚,间苯二酚厂家-淄博双和化工 | 杭州成人高考_浙江省成人高考网上报名| 搪玻璃冷凝器_厂家-越宏化工设备 | 翅片管散热器价格_钢制暖气片报价_钢制板式散热器厂家「河北冀春暖气片有限公司」 | 苏州伊诺尔拆除公司_专业酒店厂房拆除_商场学校拆除_办公楼房屋拆除_家工装拆除拆旧 | 不锈钢丸厂家,铝丸,铸钢丸-淄博智源铸造材料有限公司 | 防锈油-助焊剂-光学玻璃清洗剂-贝塔防锈油生产厂家 | 有机废气处理-rto焚烧炉-催化燃烧设备-VOC冷凝回收装置-三梯环境 | 全自动端子机|刺破式端子压接机|全自动双头沾锡机|全自动插胶壳端子机-东莞市傅氏兄弟机械设备有限公司 | 塑料异型材_PVC异型材_封边条生产厂家_PC灯罩_防撞扶手_医院扶手价格_东莞市怡美塑胶制品有限公司 | 浙江美尔凯特智能厨卫股份有限公司| 武汉高温老化房,恒温恒湿试验箱,冷热冲击试验箱-武汉安德信检测设备有限公司 | 玻璃钢型材-玻璃钢风管-玻璃钢管道,生产厂家-[江苏欧升玻璃钢制造有限公司] | 棕刚玉_白刚玉_铝酸钙-锐石新材料 | 换网器_自动换网器_液压换网器--郑州海科熔体泵有限公司 | 陶氏道康宁消泡剂_瓦克消泡剂_蓝星_海明斯德谦_广百进口消泡剂 | 欧版反击式破碎机-欧版反击破-矿山石料破碎生产线-青州奥凯诺机械 | 安规电容|薄膜电容|陶瓷电容|智旭JEC安规电容厂家| 坏男孩影院-提供最新电影_动漫_综艺_电视剧_迅雷免费电影最新观看 | 钢衬四氟管道_钢衬四氟直管_聚四氟乙烯衬里管件_聚四氟乙烯衬里管道-沧州汇霖管道科技有限公司 | 干洗加盟网-洗衣店品牌排行-干洗设备价格-干洗连锁加盟指南 | 捷码低代码平台 - 3D数字孪生_大数据可视化开发平台「免费体验」 | 聚合甘油__盐城市飞龙油脂有限公司 | 广州企亚 - 数码直喷、白墨印花、源头厂家、透气无手感方案服务商! |