您好,登錄后才能下訂單哦!
小編給大家分享一下Servlet 與 Ajax 交互一直報status=parsererror怎么辦,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
原因:servlet 返回的數據不是 Json 格式
1、JS代碼為:
var jsonStr = {'clusterNum':2,'iterationNum':3,'runTimes':4}; $.ajax({ type: "post", //http://172.22.12.135:9000/Json.json url: "/LSHome/LSHome", dataType : 'json', data : jsonStr, success: function(data,textStatus){ if(textStatus=="success"){ alert("創建任務操作成功"+data); } }, error: function(xhr,status,errMsg){ alert("創建任務操作失敗!"); } });
2、注意上面的 url 為 /LSHome/LSHome,(項目名稱為LSHome)所以在 web.xml 文件中,配置 Servlet 如下:
<servlet> <servlet-name>LSHomeServlet</servlet-name> <servlet-class>com.ys.servlet.LSHomeServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>LSHomeServlet</servlet-name> <url-pattern>/LSHome</url-pattern>
3、Servlet 中代碼為:
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //聚類數量 String clusterNum = request.getParameter("clusterNum"); //迭代次數 String iterationNum = request.getParameter("iterationNum"); //運行次數 String runTimes = request.getParameter("runTimes"); System.out.println("聚類數量為:"+clusterNum+"---迭代次數:"+iterationNum+"---運行次數:"+runTimes); PrintWriter out = response.getWriter(); out.write("success"); out.close(); }
4、結果是一直都是進入到 ajax 方法里面的 error,而且status=parsererror
xhr = Object {readyState: 4, responseText: "success", status: 200, statusText: "OK"}
5、解決辦法:
原因是通過 response 對象返回的數據格式不正確,正確方法
PrintWriter out = response.getWriter(); String jsonStr = "{\"success\":\"OK\"}"; out.write(jsonStr);
可以將返回值拼湊成 JSON 數據格式,然后會不會報status=parsererror
看完了這篇文章,相信你對“Servlet 與 Ajax 交互一直報status=parsererror怎么辦”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。