求解决springMVC 中出现getOutputStream() has already been called for this response的问题。

CocoPig 2013-01-08 10:23:29

@RequestMapping(value="queryMenusForManage")
public @ResponseBody Map<String, Object> queryMenusForManage(ModelAndView mav, HttpServletRequest request, HttpServletResponse response) throws Exception {
List<SysMenu> menuList = menuService.queryMenusForManage();
dealMenu(menuList);
NodeTree<SysMenu> nodeTree = new NodeTree<SysMenu>();
List<SysMenu> dataList = nodeTree.getRootNodeTreeForJqgrid(menuList);
Map<String, Object> resultMap = new HashMap<String, Object>();
resultMap.put("rows", dataList);
return resultMap;
}


我在controller中返回 @ResponseBody到前台,通过freemarker进行展示,就报了下面这样的错误,虽然对前台页面没啥影响,但后台一直这样报错很烦的。求解决

java.lang.IllegalStateException: getOutputStream() has already been called for this response
at org.apache.catalina.connector.Response.getWriter(Response.java:611)
at org.apache.catalina.connector.ResponseFacade.getWriter(ResponseFacade.java:198)
at javax.servlet.ServletResponseWrapper.getWriter(ServletResponseWrapper.java:112)
at org.springframework.web.servlet.view.freemarker.FreeMarkerView.processTemplate(FreeMarkerView.java:366)
at org.springframework.web.servlet.view.freemarker.FreeMarkerView.doRender(FreeMarkerView.java:283)
at org.springframework.web.servlet.view.freemarker.FreeMarkerView.renderMergedTemplateModel(FreeMarkerView.java:233)
at org.springframework.web.servlet.view.AbstractTemplateView.renderMergedOutputModel(AbstractTemplateView.java:167)
at org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:262)
at org.springframework.web.servlet.DispatcherServlet.render(DispatcherServlet.java:1180)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:950)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:852)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882)
at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:778)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:290)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.springframework.security.web.FilterChainProxy.doFilter(FilterChainProxy.java:167)
at org.springframework.web.filter.DelegatingFilterProxy.invokeDelegate(DelegatingFilterProxy.java:346)
at org.springframework.web.filter.DelegatingFilterProxy.doFilter(DelegatingFilterProxy.java:259)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:88)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:293)
at org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:879)
at org.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHandler.process(Http11AprProtocol.java:600)
at org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1703)
at java.lang.Thread.run(Thread.java:662)

我找了下,

org.springframework.web.servlet.view.freemarker.FreeMarkerView.processTemplate(FreeMarkerView.java:366)

这行代码正好是调用getWriter()的,所以是和前面的冲突了。

template.process(model, response.getWriter());
...全文
7476 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhoubaicheng88 2015-09-09
  • 打赏
  • 举报
回复
引用 1 楼 xuechunfeng 的回复:
我也遇到一个问题,就下载视频的时候,报找不到文件异常。。可是那个地址是可以访问的,上面也确实存在那个文件。。。
题目都不看,人家是Freemarker
hook_1 2014-10-14
  • 打赏
  • 举报
回复
http://stackoverflow.com/questions/3325387/infinite-recursion-with-jackson-json-and-hibernate-jpa-issue
问梦千年 2013-09-05
  • 打赏
  • 举报
回复
有没有解决啊,伤不起
a45989876 2013-07-25
  • 打赏
  • 举报
回复
我也遇到的,用easyui datagrid展示数据,翻页到最后一页就出错,页面刷不了。 有人解决没?
CocoPig 2013-01-19
  • 打赏
  • 举报
回复
不是取数据的时候出错,而是在展示页面的时候就报错了。 打开一个URL的顺序是先展示页面,然后再用AJAX去后台取数据。我把取数据的JS方法注掉后,发现还是报错,最后发现貌似跟使用EASYUI有关。在把 class="easyui-linkbutton"去掉后就没报错了,郁闷ing~~~~ 难道就只有我在这地方出过错么,网上查的全都是验证码或者下载才报错的

<a href="#" class="easyui-linkbutton" iconCls="icon-edit" plain="true" onclick="showInfo()">编辑菜单</a>
dracularking 2013-01-09
  • 打赏
  • 举报
回复
引用 5 楼 CocoPig 的回复:
展示是用freemarker来实现的,没有JSP页面更没有JAVA代码。通过controller返回JSON到前台。iteye的回答还靠谱些,说是不能返回map、void、mav,但我换了另外一种返回类型也不得
和数据类型有什么关系呢?换了这些数据类型就不会去调用getWriter了?
dracularking 2013-01-09
  • 打赏
  • 举报
回复
找找之前获得getOutputStream的地方是不是必须要调用,或者提前关闭,类似2楼给出的概念。
dracularking 2013-01-09
  • 打赏
  • 举报
回复
貌似是freemarker在渲染前台组件的时候调用了getWriter
CocoPig 2013-01-09
  • 打赏
  • 举报
回复
展示是用freemarker来实现的,没有JSP页面更没有JAVA代码。通过controller返回JSON到前台。iteye的回答还靠谱些,说是不能返回map、void、mav,但我换了另外一种返回类型也不得
dracularking 2013-01-09
  • 打赏
  • 举报
回复
接连使用getOutputStream就会报这个错(getWriter底层貌似也是使用了getOutputStream) 这里说的接连可能是指上一个获得的OutputStream没有关闭就连着用。 但仅仅从楼主给出的方法貌似看不出迹象,可能在方法内部。
zuzhilong2010 2013-01-09
  • 打赏
  • 举报
回复
看来是流使用了两次,或者是没有关闭
brightyq 2013-01-09
  • 打赏
  • 举报
回复
jsp中加下面两行试 out.clear(); out = pageContext.pushBody();
xuechunfeng 2013-01-09
  • 打赏
  • 举报
回复
我也遇到一个问题,就下载视频的时候,报找不到文件异常。。可是那个地址是可以访问的,上面也确实存在那个文件。。。

81,115

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧