ajax请求后台,后台有数据,前台得不到数据(json)

问题一:后台能得到数据,前台却进入error(),取不到json数据,也没有错误(js报错)。
        后台封装错误,注意json的格式。(就是因为后台json数据封装格式有问题,所以在前台一直拿不到数据)。
$.ajax({
   type:"post",
   url:"xxxxx.do",
   dataType:"json",
   success:function(data) {
    alert(data);
   },
   error:function(e) {
   
   }
});

$.post(
   "url",{
     data : data,
     data1 : data1
   },function(result) {
    alert(result);
   },"json"
);

问题二:在不用fastJson或者其他封装工具时,对要封装的对象的最小单位进行toString方法的重写,
        boolean和数值类型不用加双引号。
        
    /**重写entity中的toString方法**/
    @Override
    public String toString() {
        // TODO Auto-generated method stub
        return "{\"fileName\": \"" + this.fileName + "\",\"fileParentUrl\": \"" + this.fileParentUrl
                + "\",\"fileUrl\": \"" + this.fileUrl + "\",\"isDirectory\": " + this.isDirectory + ",\"size\": "
                + this.size + "}";
    }


     /**
      * servlet
     */
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        List voList = new ArrayList();
        voList = dao.getUserInfos();
        String json = "{\"data\":"+voList+"}";//封装json
        resp.setCharacterEncoding("utf-8");  
        resp.setContentType("text/json");  
        PrintWriter out = resp.getWriter();  
        out.print(json);  
        out.flush();  
        out.close();  
        System.out.println(json);

    }


问题三:json封装


你可能感兴趣的:(ajax请求后台,后台有数据,前台得不到数据(json))