解决SpringMVC返回JSON在IE中变下载的问题
2016-10-10 16:21
399 查看
最近用EasyUI写了一个小项目在火狐中测试一切正常,而在IE中测试的时候只要是采用如下方式提交表单就会出现下载对话框
而采用jQuery的Ajax提交则不会出现下载对话框
服务器端处理代码
如果将服务端方法的返回值变成String则不会出现问题,但是需要手动生成JSON数据返回而且需要客户端使用evel()来解析。
解决办法:还是继续返回Map,修改SpringMVC配置文件
问题原因:因为SpringMVC返回Map的话数据类型是application/json而返回String则是text/html,通过上面采用jQuery的Ajax提交的代码可知(我上面代码没加dataType),解决的办法就是修改他的数据类型变成text/html即可。
$("#loginForm").form("submit",{ url : "${pageContext.request.contextPath}/user/login", success : function(data) { data = eval("(" + data + ")"); if (data.success) { $.messager.progress({ text : "登录成功,正在跳转到系统主界面" }); window.location.href = "${pageContext.request.contextPath}/admin/main"; } else { $.messager.alert("提示", "登录失败,错误信息:" + data.message, "error"); } } })
而采用jQuery的Ajax提交则不会出现下载对话框
$.ajax({ url : "${pageContext.request.contextPath}/user/login", data : { loginName : $("#loginName").val(), password : $("#password").val() }, success : function(data) { if (data.success) { $.messager.progress({ text : "登录成功,正在跳转到系统主界面" }); window.location.href = "${pageContext.request.contextPath}/admin/main"; } else { $.messager.alert("提示", "登录失败,错误信息:" + data.message, "error"); } } });
服务器端处理代码
@RequestMapping(value = "/user/login", method = RequestMethod.POST) @ResponseBody public Map<String, Object> login(String loginName, String password) { Map<String, Object> result = new HashMap<>(); try { User user = userService.findByLoginNameAndPassword(loginName, password); if (user != null) { result.put("success", true); } else { result.put("success", false); result.put("message", "登录名或密码错误"); } } catch (Exception e) { result.put("success", false); result.put("message", e.getMessage()); } return result; }
如果将服务端方法的返回值变成String则不会出现问题,但是需要手动生成JSON数据返回而且需要客户端使用evel()来解析。
解决办法:还是继续返回Map,修改SpringMVC配置文件
<mvc:annotation-driven> <mvc:message-converters> <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"> <property name="supportedMediaTypes"> <list> <value>text/html;charset=UTF-8</value> </list> </property> </bean> </mvc:message-converters> </mvc:annotation-driven>
问题原因:因为SpringMVC返回Map的话数据类型是application/json而返回String则是text/html,通过上面采用jQuery的Ajax提交的代码可知(我上面代码没加dataType),解决的办法就是修改他的数据类型变成text/html即可。
相关文章推荐
- 解决SpringMVC返回JSON在IE中变下载的问题
- 解决EasyUI Form submit和SpringMVC返回JSON在IE中变下载的问题
- SpringMVC返回JSON , 解决IE下下载问题
- 解决springmvc返回json数据IE出现文件下载和json数据中文乱码问题
- 解决struts2 返回json是,在ie,360等浏览器中弹出下载框的问题。
- 解决在IE中返回JSON格式的数据时提示下载的问题
- 如何解决“文件上传返回JSON数据,在IE下提示下载文件”的问题?
- .NET easyui form提交后,返回json数据在IE下弹出下载的问题解决方法
- 解决 spring mvc 返回 json 时 在 ie 下提示下载问题
- ajaxform 提交,返回JSON时,IE提示下载的问题解决
- 如何解决“文件上传返回JSON数据,在IE下提示下载文件”的问题?
- SpringMVC 解决IE8浏览器把返回报文格式application/json当文件下载的问题
- .NET easyui form提交后,返回json数据在IE下弹出下载的问题解决方法
- SpringMVC 解决IE8浏览器把返回报文格式application/json当文件下载的问题
- Spring MVC避免IE提示下载返回的JSON 数据——解决办法
- IE中返回application/json弹出下载框问题
- 在解决spring mvc 返回json对象 ie浏览器访问会出现下载文件问题的解决方案
- 提交form会提示下载用JSON返回的以Action为名字的信息,怎么解决这个问题
- IE执行ajax时,返回JSON出现下载时怎么解决,需要配置
- jquery的ajaxForm在IE上传文件后返回json显示"文件下载"问题