ajaxForm问题集锦,一个神奇的问题:使用ajaxForm提交表单上传文件后服务器端返回json数据IE浏览器无法解析

  •   最近做一个额照片上传后裁剪的功能,用到 jquery form的ajaxform提交图片保存,然后根据返回的JSON字符串直接在页面上显示出上传的照片,并且使用jcrop进行裁剪保存:JS代码如下
Js代码  收藏代码
  1.  $('#form_portrait').ajaxForm({  
  2. ataType: 'json',  
  3.      success: function(json) {  
  4. if(json.img){         
  5.     $('#f_portrait_temp').attr("width",json.width);  
  6.     $('#f_portrait_temp').attr("height",json.height);  
  7.     $('#f_portrait_temp').attr("src","${base}"+json.img + "?r="+Math.random());  
  8.     $('#img_imgSrcPath').attr("value",json.img);  
  9.     $('#f_portrait_temp').show();  
  10.     $('#f_portrait_temp').ready(function(){  
  11.                 var api = jQuery.Jcrop('#f_portrait_temp',{  
  12.                     setSelect: [ 20, 20, 128, 155 ],  
  13.                     aspectRatio: 4/5,  
  14.                     onChange: showCoords,  
  15.                     onSelect: showCoords  
  16.                 });  
  17.         $('#btn_upload').hide();  
  18.         $('#btn_saves').show();  
  19.     });  
  20. }  
  21. else if(json.msg)  
  22.             alert(json.msg);  
  23.      }  
  24.  });  

 使用firefox和google 浏览器都很正常,firebug也能看到返回的json和图片裁剪也很正常,但唯独IE浏览器不行,点击上传按钮的时候浏览器直接弹出来下载请求页面,把json数据变成了下载文件,换了很多版本的jquery和form插件都不行。使用ajaxForm提交表单上传文件后服务器端返回json数据IE浏览器无法解析 ,到后来跟踪一个网站同样地功能才找到问题所在,原来使用ajaxForm,必须以html格式返回json数据. 也就是 response.setContentType("text/html; charset=utf-8"); 这样返回的数据才能被设置到回调函数里面. 而且貌似格式必须是 "key":"value" 也就是双引号,单引号还不行,这算不算一个bug呢?明明

Js代码  收藏代码
  1. dataType: 'json',  

却要返回html。

Java代码  收藏代码
  1. RenderUtils.renderHtml(response, json.toString(), "no-cache:false");  

 

 

  • 表单中带有 <input type="file" >文件类型的输入框 则使用ajaxForm时会自动将Content-Type设置为文件上传的,这会导致Springmvc框架无法获取到表单数据,正常的接收头 Content-Type application/x-www-form-urlencoded; charset=UTF-8

 

 

还有一个插件有类似的问题

 

jquery插件ajaxfileupload 不能解析服务器端响应的json

 

contentType参数是一定要有的,否则浏览器总是提示将返回的JSON结果另存为文件,不会交给ajaxfileupload处理。这是因为struts2 JSON Plugin默认的contentType为application/json,而ajaxfileupload则要求为text/html。

http://usenrong.iteye.com/blog/1327724

  1. da shang
    donate-alipay
               donate-weixin weixinpay

发表评论↓↓