您的位置:首页 > Web前端

ajaxfileupload上传文件,返回json数据报错的问题。 Resource interpreted as Document but transferred with MIME type ap

2017-08-10 14:22 1061 查看
转自:http://www.cnblogs.com/losedo/p/4235674.html

在使用ajaxfileupload上传文件的时候,文件上传成功了,但是返回的json数据一直解析不了。一直提示:Resource interpreted as Document but transferred with MIME type application/json,从字面上理解返回的是文档不能转换为json。但是从服务器那边返回的response里data-type确实是applicaiton/json。困扰很久,查看ajaxfileupload源代码发现,其实ajaxfileupload其实使用iframe+form的方式实现异步上传文件的,如下:

//////////////////////////////////////////////////////////////////

    //穿件form表单函数

    createUploadForm: function (id, fileElementId, data) {

        //create form

        var formId = 'jUploadForm' + id;

        var fileId = 'jUploadFile' + id;

        var form = jQuery('<form action="" method="POST" name="' + formId + '" id="' + formId + '"     enctype="multipart/form-data"></form>');

 

//上传调用接口

 ajaxFileUpload: function (s) {

        // TODO introduce global settings, allowing the client to modify them for all requests, not only timeout

        s = jQuery.extend({}, jQuery.ajaxSettings, s);

        var id = s.fileElementId;

        var form = jQuery.createUploadForm(id, s.fileElementId, s.data); //创建form表单

        var io = jQuery.createUploadIframe(id, s.secureuri);//创建Iframe

////////////////////////////////////////////////////////

 

知道了上传流程,明白了问题出现在哪里了,是用Iframe的时候,返回的时候会添加上html和body标签。jquery不能直接解析的话,只能自己解析了。

        ajaxfileupload调用的时候dataType不用设置,使用默认text/html.返回的数据作处理:

        var str = $(data).find("body").text();//获取返回的字符串

        var json = $.parseJSON(str);//把字符串转化为json对象
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐