SpringMVC+ajaxFileUpload上传图片 IE浏览器弹下载框问题解决方式

如题,简单记录一下这个问题的解决的方法,导致问题的核心原因是:ajaxfileupload不支持响应头ContentType为application/json的设置。而且IE也不支持这样的格式,而当我们用SpringMVC的@ResponseBody注解的时候会自己主动将响应类型设置为application/json。所以解决的方法仅仅有手动设置响应类型。

Step1 弃用@ResponseBody,通过流手动输出响应,并指定响应类型为text/html

@RequestMapping(value = "/fileImport2")
	public Map<String, Object> fileImport2(HttpServletRequest request,
			HttpServletResponse response, MultipartHttpServletRequest req,
			@RequestParam("filename") MultipartFile uploadFile) {
		response.setContentType("text/html;charset=utf-8");
		try {
			// 文件上传
			String updateLoadPath = FileOperateUtil.uploadExcel(req, request,
					uploadFile);
			String publishPath = request.getSession().getServletContext()
					.getRealPath("/");
			//...略
			response.getWriter().write("{\"data\":\"ok\"}");
		} catch (Exception e) {
			e.printStackTrace();
			try {
				response.getWriter().write("{\"data\":\"error\"}");
			} catch (IOException e1) {
				// TODO Auto-generated catch block
				e1.printStackTrace();
			}
		}

		return null;
	}

Step2 将$.ajaxFileUpload的dataType设置为text(否则回调函数的值是[object.object])

	$.ajaxFileUpload
            (
                {
                    url: postPath+"/app/studentScore/fileImport2", //用于文件上传的server端请求地址
                    secureuri: false, //是否须要安全协议,一般设置为false
                    fileElementId: ‘filename‘, //文件上传域的ID
                    dataType: ‘text‘, //返回值类型 一般设置为json
                    success: function (data)  //server成功响应处理函数
                    {
                    		alert(data);
                    		var repObj = $.parseJSON(data);
                            if (repObj.data == ‘ok‘)
                            {
                                alert("导入成功!");
                            }
                            else
                            {
                                alert("数据异常!");
                            }
                    }
                }
            );

问题攻克了, 最后简单看一下FireBug的调试信息:

时间: 2024-09-30 07:03:39

SpringMVC+ajaxFileUpload上传图片 IE浏览器弹下载框问题解决方式的相关文章

SpringMVC+ajaxFileUpload上传图片 IE浏览器弹下载框问题解决方案

如题,简单记录一下这个问题的解决办法,导致问题的核心原因是:ajaxfileupload不支持响应头ContentType为application/json的设置,并且IE也不支持这种格式,而当我们用SpringMVC的@ResponseBody注解的时候会自动将响应类型设置为application/json,所以解决办法只有手动设置响应类型. Step1 弃用@ResponseBody,通过流手动输出响应,并指定响应类型为text/html @RequestMapping(value = "/

js 简单的浏览器弹出框输出。

<!DOCTYPE html><html><head> <title></title> <meta charset="utf-8"> <script type="text/javascript"> function Dj(){ alert('傻逼'); } </script> <style type="text/css"> .a{ widt

bootstrap-js(六)弹出框

实例 为任意元素添加一小块浮层,用于存放非主要信息. 弹出框的标题和内容的长度都是零的话将永远不会被显示出来. 初始化 由于性能的原因,工具提示和弹出框的 data 编程接口(data api)是必须要手动初始化的. 在一个页面上一次性初始化所有弹出框的方式是通过 data-toggle 属性选中 <!DOCTYPE HTML><html><head><link href="/stylesheets/bootstrap.min.css" rel

弹出框 popover.js

弹出框 popover.js 为任意元素添加一小块浮层,就像 iPad 上一样,用于存放非主要信息. 弹出框的标题和内容的长度都是零的话将永远不会被显示出来. 插件依赖 弹出框依赖 工具提示插件 ,因此,如果你定制了 Bootstrap,一定要注意将依赖的插件编译进去. 初始化 由于性能的原因,工具提示和弹出框的 data 编程接口(data api)是必须要手动初始化的. 在一个页面上一次性初始化所有弹出框的方式是通过 data-toggle 属性选中他们: 复制 复制 $(function

springmvc导出excel并弹出下载框

加入对应的jar包,包括springmvc,poi的, spring jar包在此不列举出来,主要是poi包,如下图所示 下载地址:http://download.csdn.net/download/huawei2010_2011_2012/5034041,或者搜poi3.9 实体类: public class Project { private Integer id; private String name; private String technology;//所用技术 private S

easyui出口excel无法下载框弹出的办法来解决

使用前ajax发,码如下面(ActionUrl一般处理程序ashx路径): $.ajax({ url: ActionUrl + '?action=export&ID=' + $('#fm_ID').val(), dataType: 'json', success: function (jsonstr) { //top.art.dialog.tips('导出成功.'); } }); 没办法弹出下载框. 直接浏览器地址栏输入相关页面地址并打开能够弹出下载框下载,考虑可能是iframe的缘故. 由于输

java生成excel表格和pdf并实现下载弹出框

今天在pdf和excel中都实现了在浏览器弹出下载框 将之前在网上查找的生成excel表格代码稍微修改下: public class CreateSimpleExcelToDisk { /** * @功能:手工构建一个简单格式的Excel */ private static List<News> getNews() throws Exception { List<News> data = new ArrayList<News>(); NewsDao dao = new

【转】php让图片弹出下载框的方法

在做图片下载站时,常常需要给用户下载图片,但图片浏览器是直接可以打开的.怎么办呢,有没有什么方法可以让图片类型的文件弹出下载框下载呢, phperz.com 当然是有的,php的header函数就可以提供这种方法 php程序员之家 以下代码你可以copy下来测式一下 www.phperz.com 以下为引用的内容:<?php$filename = "123.jpg";//图片地址,可以绝对地址也可以相对地址header("Content-Type: applicatio

Java POI 导出EXCEL经典实现 Java导出Excel弹出下载框

在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.而数据导出的格式一般是EXCEL或者PDF,我这里就用两篇文章分别给大家介绍下.(注意,我们这里说的数据导出可不是数据库中的数据导出!么误会啦^_^) 呵呵,首先我们来导出EXCEL格式的文件吧.现在主流的操作Excel文件的开源工具有很多,用得比较多的就是Apache的POI及JExcelAPI.这里我们用Apache POI!我们先去Apach