ajaxFileUpload插件上传文件 返回 syntaxError :unexpected token <

前端之家收集整理的这篇文章主要介绍了ajaxFileUpload插件上传文件 返回 syntaxError :unexpected token <前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
  1. <tableid="deploy_application"class="bordered-table">@H_502_21@
  2. <tr>@H_502_21@
  3. <tdid="application_file">@H_502_21@
  4. <inputid="file_field"type="file"name="application"size="20"/>@H_502_21@
  5. </td>@H_502_21@
  6. <tdid="application_submit">@H_502_21@
  7. <inputid="submit_button"type="submit"value="Upload"onclick="uploadFile()"/>@H_502_21@
  8. </td>@H_502_21@
  9. </tr>@H_502_21@
  10. </table>@H_502_21@


最近在使用ajaxFileUpload插件文件上传时,后端返回json格式的数据,js代码如下:

  1. functionajaxFileUpload(){ @H_502_21@
  2. @H_502_21@
  3. $.ajaxFileUpload @H_502_21@
  4. ( @H_502_21@
  5. { @H_502_21@
  6. url:'/upload',@H_502_21@
  7. secureuri:false,@H_502_21@
  8. fileElementId:'file_field',@H_502_21@
  9. dataType:'json',//这里选择了json @H_502_21@
  10. @H_502_21@
  11. success:function(data,status){ @H_502_21@
  12. alert(data); @H_502_21@
  13. },@H_502_21@
  14. @H_502_21@
  15. error:function(data,status,e){ @H_502_21@
  16. alert(e); @H_502_21@
  17. } @H_502_21@
  18. } @H_502_21@
  19. ) @H_502_21@
  20. }@H_502_21@


结果在chrome和FireFox浏览器出现如下错误



先在网上找了下解决办法,stackoverflow上有说修改ajaxFileUpload源码的方法,试了下,不能用,问题依旧,只能自己排查下原因了。从错误提示上看有点像是json数据中出现了<(尖括号),为了看到json数据,将js修改如下:
  1. functionajaxFileUpload(){ @H_502_21@
  2. @H_502_21@
  3. $.ajaxFileUpload @H_502_21@
  4. ( @H_502_21@
  5. { @H_502_21@
  6. url:'/upload',@H_502_21@
  7. dataType:'content',//这里修改为content @H_502_21@
  8. @H_502_21@
  9. success:function(data,e){ @H_502_21@
  10. alert(e); @H_502_21@
  11. } @H_502_21@
  12. } @H_502_21@
  13. ) @H_502_21@
  14. }@H_502_21@


结果返回的json数据如猜测,json数据被包含在一个<pre></pre>的标签中,如下图:



网上查了下原因,是因为Server端的Response上加上了contentType="application/json"。但有时后端这么做是必须的,所以修改ajaxFileUpload源码,将<pre></pre>标签去掉,如下:
  1. uploadHttpData:function(r,type){ @H_502_21@
  2. vardata=!type; @H_502_21@
  3. data=type=="xml"||data?r.responseXML:r.responseText; @H_502_21@
  4. //Ifthetypeis"script",evalitinglobalcontext @H_502_21@
  5. if(type=="script") @H_502_21@
  6. jQuery.globalEval(data); @H_502_21@
  7. //GettheJavaScriptobject,ifJSONisused. @H_502_21@
  8. if(type=="json"){ @H_502_21@
  9. ////////////以下为新增代码/////////////// @H_502_21@
  10. data=r.responseText; @H_502_21@
  11. varstart=data.indexOf(">"); @H_502_21@
  12. if(start!=-1){ @H_502_21@
  13. varend=data.indexOf("<",start+1); @H_502_21@
  14. if(end!=-1){ @H_502_21@
  15. data=data.substring(start+1,end); @H_502_21@
  16. } @H_502_21@
  17. } @H_502_21@
  18. ///////////以上为新增代码/////////////// @H_502_21@
  19. eval("data="+data); @H_502_21@
  20. } @H_502_21@
  21. //evaluatescriptswithinhtml @H_502_21@
  22. if(type=="html") @H_502_21@
  23. jQuery("<div>").html(data).evalScripts(); @H_502_21@
  24. @H_502_21@
  25. returndata; @H_502_21@
  26. }@H_502_21@


至此,大工告成,ajaxFileUpload的dataType正常使用json。

原文地址;http://liwx2000.iteye.com/blog/1540321

猜你在找的Ajax相关文章