這篇文章主要介紹了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"}
############################### ####原因是透過response 物件回傳的資料格式不正確,正確方法#########
PrintWriter out = response.getWriter(); String jsonStr = "{\"success\":\"OK\"}"; out.write(jsonStr);#########上面是我整理給大家的,希望今後會對大家有幫助。 ######相關文章:#########PHP ###ajax###實作取得新聞資料案例詳解###############PHP AJAX 如何實作投票器功能###############PHP如何取得###ajax###中的headers(案例)############## ############
以上是Servlet 與 Ajax 互動一直報status=parsererror的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!