ajaxFileUpload plugin上传文件 chrome、Firefox中出现SyntaxError:unexpected token <

前端之家收集整理的这篇文章主要介绍了ajaxFileUpload plugin上传文件 chrome、Firefox中出现SyntaxError:unexpected token <前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
  1. <tableid="deploy_application"class="bordered-table">
  2. trtdid="application_file"inputid="file_field"type="file"name="application"size="20"/>
  3. </tdtdid="application_submit"inputid="submit_button"type="submit"value="Upload"onclick="uploadFile()"table>


最近在使用ajaxFileUpload插件文件上传时,后端返回json格式的数据,js代码如下:
Js代码
    functionajaxFileUpload(){
  1. $.ajaxFileUpload
  2. (
  3. {
  4. url:'/upload',
  5. secureuri:false,250)"> fileElementId:'file_field',250)"> dataType:'json',//这里选择了json
  6. success:function(data,status){
  7. alert(data);
  8. },250)"> error: alert(e);
  9. }
  10. )
  11. }

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

先在网上找了下解决办法,stackoverflow上有说修改ajaxFileUpload源码的方法,试了下,不能用,问题依旧,只能自己排查下原因了。从错误提示上看有点像是json数据中出现了<(尖括号),为了看到json数据,将js修改如下:
dataType:'content',0); padding:0px; margin:0px; width:auto; border:0px">//这里修改为content
  • 结果返回的json数据如猜测,json数据被包含在一个<pre></pre>的标签中,如下图:
    网上查了下原因,是因为Server端的Response上加上了contentType="application/json"。但有时后端这么做是必须的,所以修改ajaxFileUpload源码,将<pre></pre>标签去掉,如下:
    uploadHttpData:function(r,type){
  • vardata=!type;
  • data=type=="xml"||data?r.responseXML:r.responseText;
  • //Ifthetypeis"script",evalitinglobalcontext
  • if(type=="script")
  • jQuery.globalEval(data);
  • //GettheJavaScriptobject,ifJSONisused.
  • if(type=="json"){
  • ////////////以下为新增代码///////////////
  • data=r.responseText;
  • varstart=data.indexOf(">");
  • if(start!=-1){
  • varend=data.indexOf("<",start+1);
  • if(end!=-1){
  • data=data.substring(start+1,end);
  • ///////////以上为新增代码///////////////
  • eval("data="+data);
  • //evaluatescriptswithinhtml
  • if(type=="html")
  • jQuery("<div>").html(data).evalScripts();
  • returndata;
  • @H_958_301@至此,大工告成,ajaxFileUpload的dataType正常使用json。

    @H_958_301@

    @H_958_301@转自:http://liwx2000.iteye.com/blog/1540321

  • 猜你在找的Ajax相关文章