解决“Resource interpreted as Document but transferred with MIME type application/json”问题

Posted 菜鸟jing

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决“Resource interpreted as Document but transferred with MIME type application/json”问题相关的知识,希望对你有一定的参考价值。

在上传图片时,使用ajax提交,返回的数据格式为json。在测试时发现IE浏览器中,上传图片后,没有显示图片,而是弹出一个提示:是否保存UploadImg.json文件;而在其他浏览器中正常。

在Chrome中调试后发现,图片上传成功后,浏览器给出了一个警告:Resource interpreted as Document but transferred with MIME type application/json。

原来后台代码在返回json数据时,响应数据的ContentType默认为“application/json”,IE浏览器的新版本(IE10、IE11)会把该类型解释为文件下载操作。

后台代码:

public JsonResult UploadImgToLocal()
        {
            var FileMaxSize = 10240; //文件大小,单位为K     
            var model = new ImgUploadResult();
            try
            {
                HttpPostedFile myFile = HttpContext.Current.Request.Files[0];
                if (myFile != null)
                {
                    string fileExtension = myFile.FileName.Substring(myFile.FileName.LastIndexOf(.));
                    if (!CheckValidExt(fileExtension))
                    {
                        return Json(new { UploadCode = 104, massege = "文件格式错误" });
                    }
                    else
                    {
                        if (myFile.ContentLength > FileMaxSize * 1024)
                        {
                            return Json(new { UploadCode = 105, massege = "文件过大" });
                        }
                        else
                        {
                                //上传

                                //返回结果
                                return Json(new { UploadCode = 100, massege = "", sourceUrl = model.SourceImgUrl, bigUrl = model.BigImgUrl, thumbUrl = model.ThumbImgUrl });
                                #endregion
                            }
                            catch
                            {
                                return Json(new { UploadCode = 101, massege = "上传失败" });
                            }
                        }
                    }
                }
                else
                {
                    return Json(new { UploadCode = 102, massege = "请上传文件" });
                }
            }
            catch
            {
                return Json(new { UploadCode = 101, massege = "上传失败" });
            }
        }

将代码中的

return Json(new { UploadCode = 100, massege = "", sourceUrl = model.SourceImgUrl, bigUrl = model.BigImgUrl, thumbUrl = model.ThumbImgUrl });

改为:

JsonResult json = new JsonResult();
json.ContentType = "text/html";
json.Data = new { UploadCode = 100, massege = "", sourceUrl = model.SourceImgUrl, bigUrl = model.BigImgUrl, thumbUrl = model.ThumbImgUrl };
return json;

修改响应数据的ContentType类型后,返回的数据类型为json字符串,这样就会兼容IE浏览器了。


以上是关于解决“Resource interpreted as Document but transferred with MIME type application/json”问题的主要内容,如果未能解决你的问题,请参考以下文章

vs2008解决方案资源管理器不显示解决方案

什么是 沙盒解决方案

解决PowerShell乱码问题

如何解决解决方案中现有项目的c#CS0006错误

关于问题解决与事件解决的思考

「解决方案架构」解决方案架构概述