AJAX中Get請(qǐng)求報(bào)錯(cuò)404的原因以及解決辦法
背景環(huán)境
已學(xué)習(xí)java基礎(chǔ),html,css,js,jquery,bootstrap,layui,maven,servlet和jsp,剛進(jìn)入spring的學(xué)習(xí),了解了控制反轉(zhuǎn)和依賴注入后,自己嘗試將一個(gè)使用layui開(kāi)發(fā)的前端項(xiàng)目,整合到spring中實(shí)現(xiàn)前后端簡(jiǎn)單的交互,借此來(lái)理清前后端交互的主要流程。
項(xiàng)目結(jié)構(gòu)
主要項(xiàng)目結(jié)構(gòu)
- java
- com.sisyphus
- vo
- ResultInfo //數(shù)據(jù)封裝成的對(duì)象
- LoginServlet //處理請(qǐng)求的后端代碼
- webapp
- html //存放頁(yè)面
- login.jsp
- js //jquery
- layui //前端項(xiàng)目頁(yè)面
- index.jsp //首頁(yè)
在介紹完項(xiàng)目的結(jié)構(gòu)之后,對(duì)項(xiàng)目做一個(gè)簡(jiǎn)單的說(shuō)明,并展示主要代碼:
通過(guò)拷貝了前端項(xiàng)目的一個(gè)表單,表單中包含一個(gè)text類型的input,一個(gè)password類型的input,還有一個(gè)button類型的按鈕,通過(guò)onclick屬性調(diào)用函數(shù),取到用戶輸入的數(shù)據(jù)并進(jìn)行校驗(yàn),滿足校驗(yàn)后發(fā)送ajax請(qǐng)求,將data返回指定的后臺(tái)url。
function login(){ //獲取數(shù)據(jù) var username = $("#username").val(); var password = $("#password").val(); console.log(username) console.log(password) //校驗(yàn)參數(shù) if(isEmpty(username)){ $("#sp").html("用戶名不能為空"); return; } if(isEmpty(password)){ $("#sp").html("密碼不能為空"); return; } //發(fā)送請(qǐng)求 $.ajax({ type:'get', /*url:'../userlogin',*/ url:'userlogin', data:{ username:username, password:password }, dataType:'json', success:function(data){ if(data.code == 1){ //操作成功 //跳轉(zhuǎn) console.log(data); alert("登錄成功") window.location.href = "../index.jsp"; }else{ //操作失敗 console.log(data); $("#sp").html(data.msg); } } }); } //非空校驗(yàn) function isEmpty(str){ if(str == undefined || str.trim() == ""){ return true; } return false; }
在后臺(tái)中創(chuàng)建返回值類型對(duì)象,接收數(shù)據(jù)并進(jìn)行校驗(yàn)檢查,最后轉(zhuǎn)換成相應(yīng)的數(shù)據(jù)類型進(jìn)行響應(yīng),寫出給前臺(tái)。
response.setContentType("application/json;charset=UTF-8"); //創(chuàng)建一個(gè)返回值對(duì)象 ResultInfo resultInfo = new ResultInfo(); resultInfo.setCode(1); //接收參數(shù) String username = request.getParameter("username"); String password = request.getParameter("password"); System.out.println(username+"----"+password); //參數(shù)校驗(yàn) if(username == null || "".equals(username.trim())){ resultInfo.setCode(0); resultInfo.setMsg("賬號(hào)不存在"); } if(password == null || "".equals(password.trim())){ resultInfo.setCode(0); resultInfo.setMsg("賬號(hào)不存在"); } if(!"zhangsan".equals(username)){ resultInfo.setCode(0); resultInfo.setMsg("用戶不存在"); } if("zhangsan".equals(username)&&!"123456".equals(password)){ resultInfo.setCode(0); resultInfo.setMsg("密碼有誤"); } //將數(shù)據(jù)轉(zhuǎn)換成json格式的數(shù)據(jù) String ri = JSON.toJSONString(resultInfo); //寫出json數(shù)據(jù) response.getWriter().write(ri);
問(wèn)題成因
在第一次運(yùn)行項(xiàng)目時(shí),我的login.jsp在html目錄中,而在Java代碼中的注解如下:
@WebServlet("/userlogin")
在jsp文件的ajax請(qǐng)求中url標(biāo)識(shí)將請(qǐng)求前臺(tái)的地址,按照當(dāng)前的注解我們會(huì)出現(xiàn)get404:
我們點(diǎn)進(jìn)去觀察:
發(fā)現(xiàn)它的地址是war包下的html下的userlogin,很明顯這個(gè)路徑是不對(duì)的,我們?cè)谧⒔庵兄粯?biāo)記了@WebServlet(“/userlogin”)。于是我們可以認(rèn)為出現(xiàn)get404的原因是ajax請(qǐng)求到錯(cuò)誤的路徑。
很明顯ajax在尋找url時(shí)預(yù)先拼接上了自己所在的目錄html。
解決辦法1
將login.jsp放在webapp根目錄下,但是顯然當(dāng)我們項(xiàng)目的頁(yè)面越來(lái)越多之后,都放在根目錄下很不合適,于是我推薦采取第二種辦法:
解決辦法2
在ajax請(qǐng)求的url前加上…/返回根路徑進(jìn)行前端請(qǐng)求路徑的匹配:
//發(fā)送請(qǐng)求 $.ajax({ type:'get', url:'../userlogin', /*url:'userlogin',*/ data:{ username:username, password:password }, dataType:'json',
至此問(wèn)題圓滿解決。
總結(jié)
到此這篇關(guān)于AJAX中Get請(qǐng)求報(bào)錯(cuò)404的原因以及解決辦法的文章就介紹到這了,更多相關(guān)AJAX Get請(qǐng)求報(bào)錯(cuò)404內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java視頻格式轉(zhuǎn)化的實(shí)現(xiàn)方法
這篇文章主要為大家詳細(xì)介紹了Java視頻格式轉(zhuǎn)化的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02java實(shí)現(xiàn)163郵箱發(fā)送郵件到qq郵箱成功案例
這篇文章主要為大家分享了java實(shí)現(xiàn)163郵箱發(fā)送郵件到qq郵箱成功案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05mybatis逆向工程與分頁(yè)在springboot中的應(yīng)用及遇到坑
最近在項(xiàng)目中應(yīng)用到springboot與mybatis,在進(jìn)行整合過(guò)程中遇到一些坑,在此將其整理出來(lái),分享到腳本之家平臺(tái)供大家參考下2018-09-09使用Spring處理x-www-form-urlencoded方式
這篇文章主要介紹了使用Spring處理x-www-form-urlencoded方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-11-11Json 自定義使用函數(shù)的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇Json 自定義使用函數(shù)的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10基于Spring p標(biāo)簽和c標(biāo)簽注入方式
這篇文章主要介紹了Spring p標(biāo)簽和c標(biāo)簽注入方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-09-09