2

Java ベースの構成で Spring 3 を使用しています。

Excelシートをユーザーにエクスポートするモジュールがあります(つまり、シートをユーザーにダウンロードします)

ログで次の例外が発生しました....しかし、正常にエクスポートされます:

java.lang.IllegalStateException: getOutputStream() は、org.apache.catalina.connector.ResponseFacade.getWriter(ResponseFacade. java:214) で javax.servlet.ServletResponseWrapper.getWriter(ServletResponseWrapper.java:105) で javax.servlet.ServletResponseWrapper.getWriter(ServletResponseWrapper.java:105) で org.springframework.web.servlet.view.freemarker.FreeMarkerView.processTemplate (FreeMarkerView.java:366) org.springframework.web.servlet.view.freemarker.FreeMarkerView.doRender(FreeMarkerView.java:283) org.springframework.web.servlet.view.freemarker.FreeMarkerView.renderMergedTemplateModel(FreeMarkerView.java) :233) org.springframework.web.servlet.view.AbstractTemplateView.renderMergedOutputModel(AbstractTemplateView.java:167) で org.springframework.web.servlet.view.AbstractView.render(AbstractView.java:262) で org.springframework.web org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:927) の .servlet.DispatcherServlet.render(DispatcherServlet.java:1157) org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:827) ) org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:882) で org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:778) で javax.servlet.http.HttpServlet.service( HttpServlet.java:621) で javax.servlet.http.HttpServlet.service(HttpServlet.java:728) で org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305) で org.apache.catalina.core.ApplicationFilterChain.doFilter (ApplicationFilterChain.java:210) org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:311) で org.springframework.security.web.access.intercept.FilterSecurityInterceptor.invoke(FilterSecurityInterceptor.java:116) ) org.springframework.security.web.access.intercept.FilterSecurityInterceptor.doFilter(FilterSecurityInterceptor.java:83) で org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323) org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323) で org.springframework.security で org.springframework.security.web.access.ExceptionTranslationFilter.doFilter(ExceptionTranslationFilter.java:113) で.web.session.SessionManagementFilter.doFilter(SessionManagementFilter.java:101) at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323)doFilter(SessionManagementFilter.java:101) at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323)doFilter(SessionManagementFilter.java:101) at org.springframework.security.web.FilterChainProxy$VirtualFilterChain.doFilter(FilterChainProxy.java:323)

調査の結果、getOutputStream() メソッドは応答に対して 1 回しか呼び出せないことがわかりました。ただし、ユーザーが次のようにシートをエクスポートする必要があるたびに呼び出します。

public void exportExcel(HttpServletResponse response) throws Exception {

    response.setContentType("application/vnd.ms-excel");

    response.setHeader("Content-disposition", "attachment;filename=" + sheetName + "");


    ByteArrayOutputStream excelFileByteArrayOutputStream =

    excelFileByteArrayOutputStream.writeTo(response.getOutputStream());
    excelFileByteArrayOutputStream.flush();
    response.flushBuffer();
    excelFileByteArrayOutputStream.close();
  }

フリーマーカー構成:

@Bean
  public FreeMarkerViewResolver viewResolver() {
    FreeMarkerViewResolver freeMarkerViewResolver = new FreeMarkerViewResolver();
    freeMarkerViewResolver.setCache(true);
    freeMarkerViewResolver.setPrefix("");
    freeMarkerViewResolver.setSuffix(".ftl");
    return freeMarkerViewResolver;
  }

  @Bean
  public FreeMarkerConfigurer freemarkerConfig() {
    FreeMarkerConfigurer freeMarkerConfigurer = new FreeMarkerConfigurer();
    freeMarkerConfigurer.setTemplateLoaderPath("/WEB-INF/freemarker/");
    Properties settings = new Properties();
    settings.setProperty("number_format", "0.######");
    freeMarkerConfigurer.setFreemarkerSettings(settings);
    Map variables = new java.util.HashMap<String, Object>();

    variables.put("xml_escape", new XmlEscape());
    freeMarkerConfigurer.setFreemarkerVariables(variables);
    return freeMarkerConfigurer;
  }

@Controlle ...シートがエクスポートされた後、指定したようにホームページにリダイレクトされることはありません:

  @RequestMapping(value = "/smth", method = RequestMethod.GET)
  public ModelAndView exportSheet(HttpServletResponse response,
                                                           Bean aBean,
                                                           BindingResult result) throws Exception {

//Some Code
    return new ModelAndView("/home");
  }

私の WebApplicationInitializer:

public class SpringWebApplicationInitializer implements WebApplicationInitializer {

  @Override
  public void onStartup(final ServletContext servletContext) throws ServletException {

    // Create the 'root' Spring application context
    AnnotationConfigWebApplicationContext rootContext = new AnnotationConfigWebApplicationContext();
    rootContext.register(WebConfiguration.class);

    // Manage the lifecycle of the root application context
    servletContext.addListener(new ContextLoaderListener(rootContext));

    // Create the dispatcher servlet's Spring application context
    AnnotationConfigWebApplicationContext dispatcherContext = new AnnotationConfigWebApplicationContext();
    dispatcherContext.register(DispatcherConfiguration.class);

    // Register and map the dispatcher servlet
    ServletRegistration.Dynamic dispatcher =
      servletContext.addServlet("dispatcher", new DispatcherServlet(dispatcherContext));
    dispatcher.setLoadOnStartup(1);
    dispatcher.addMapping("/");

    // Register Spring Security Filter
    DelegatingFilterProxy securityFilter = new DelegatingFilterProxy();
    FilterRegistration.Dynamic securityFilterRegistration =
      servletContext.addFilter("springSecurityFilterChain", DelegatingFilterProxy.class);
    securityFilterRegistration.addMappingForUrlPatterns(null, false, "/*");
  }


}

この問題をくすぐる方法を教えてください。

4

0 に答える 0