IllegalStateException
От: oson Россия  
Дата: 19.12.07 16:12
Оценка:
Господа!
Подскажите пожалуйста, в чем причина такого exception?
Используется JSF и JasperReports.
На страничке имеется линк

  <h:commandLink action="#{myBean.showReport}" actionListener="#{myBean.putParameters}">
                        <h:outputText value="Report" />
 </h:commandLink>


В myBean
  public String showReport()
    {
        if (reportName == null)
        {
            return null;
        }

        prepareReport();
        FacesContext facesContext = FacesContext.getCurrentInstance();
        ExternalContext externalContext = facesContext.getExternalContext();
        HttpServletRequest servletRequest = (HttpServletRequest) externalContext.getRequest();
        if (servletRequest != null)
        {
            servletRequest.setAttribute("nameInSession", reportName);
        }
        return "showReport";
    }


В faces-config.xml
<navigation-rule>
        <from-view-id>*</from-view-id>
        <navigation-case>
            <from-outcome>showReport</from-outcome>
            <to-view-id>/report</to-view-id>
        </navigation-case>
    </navigation-rule>



В web.xml
   <servlet>
        <servlet-name>ReportServlet</servlet-name>
        <servlet-class>my.servlets.ReportServlet</servlet-class>
    </servlet>

    <servlet-mapping>
        <servlet-name>ReportServlet</servlet-name>
        <url-pattern>/report</url-pattern>
    </servlet-mapping>


В ReportServlet

  private void showReport(ReportProvider reportProvider, HttpServletResponse response, String nameForStore) throws IOException
  {
      byte[] reportContentInBytes = myBean.getBytes();
      String format = myBean.getFormat();
      String ext = null;
      if (format.equalsIgnoreCase("application/pdf"))
      {
          ext = ".pdf";
      }
     

      if (reportContentInBytes != null && nameForStore != null && ext != null)
      {
          response.setContentType("application/x-download");
          response.setContentLength(reportContentInBytes.length);
          response.setHeader("Content-Disposition", "attachment; filename=" + nameForStore + ext);
          OutputStream outputStream = response.getOutputStream();
          outputStream.write(reportContentInBytes, 0, reportContentInBytes.length);
          outputStream.flush();
          outputStream.close();
      }
  }


В месте OutputStream outputStream = response.getOutputStream(); выпадает exception
ERROR [org.apache.catalina.core.ContainerBase.[jboss.web].[localhost].[/cm84].[FacesServlet]] Servlet.service() for servlet FacesServlet threw exception
java.lang.IllegalStateException
    at com.sun.faces.application.ViewHandlerResponseWrapper.getOutputStream(ViewHandlerResponseWrapper.java:179)
    at my.servlets.ReportServlet.showReport(ReportServlet.java:86)
    at my.servlets.ReportServlet.service(ReportServlet.java:43)
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:803)


Где искать причину?
Re: IllegalStateException
От: Георгий  
Дата: 19.12.07 22:08
Оценка:
Здравствуйте, oson, Вы писали:

O>Подскажите пожалуйста, в чем причина такого exception?

Трудно сказать, в чем причина. У вас сервлет jsf как замаплен?

Вот пример генерации отчета из одного приложения (код упрощен). Может пригодтся:

public class ExportPhaseListener implements PhaseListener {

    public void beforePhase(PhaseEvent event) {
        FacesContext context = event.getFacesContext();
        HttpServletResponse response = (HttpServletResponse) context
                .getExternalContext().getResponse();
        Object object = context.getExternalContext().getRequest();

        HttpServletRequest request = (HttpServletRequest) object;

        if (request.getServletPath().equals("тут путь для отчета") {
            return;
        }

        response.setContentType("text/csv");
        response.setContentLength(value.length());
        response.setHeader("Content-Disposition", "inline;filename="
                + item.getName() + ".csv");

        try {
            response.getWriter().write(value);
        } catch (IOException e) {
            e.printStackTrace();
        }
        event.getFacesContext().responseComplete();
    }

    public PhaseId getPhaseId() {
        return PhaseId.RESTORE_VIEW;
    }

    public void afterPhase(PhaseEvent event) {
    }
}


Т.е. по сути не сервлетом, а вклиниваемся в jsf life cycle.
Re: IllegalStateException
От: LobnYA  
Дата: 20.12.07 05:55
Оценка:
Здравствуйте, oson, Вы писали:

O>
O>  private void showReport(ReportProvider reportProvider, HttpServletResponse response, String nameForStore) throws IOException
O>  {
O>      byte[] reportContentInBytes = myBean.getBytes();
O>      String format = myBean.getFormat();
O>      String ext = null;
O>      if (format.equalsIgnoreCase("application/pdf"))
O>      {
O>          ext = ".pdf";
O>      }
     

O>      if (reportContentInBytes != null && nameForStore != null && ext != null)
O>      {
O>          response.setContentType("application/x-download");
O>          response.setContentLength(reportContentInBytes.length);
O>          response.setHeader("Content-Disposition", "attachment; filename=" + nameForStore + ext);
O>          OutputStream outputStream = response.getOutputStream();
O>          outputStream.write(reportContentInBytes, 0, reportContentInBytes.length);
O>          outputStream.flush();
O>          outputStream.close();
O>      }
O>  }

O>


может причина в том, что ты пытаешься взять OutputStream после того как уже установил что-то в response?
попробуй сделать OutputStream outputStream = response.getOutputStream() до response.set...
 
Подождите ...
Wait...
Пока на собственное сообщение не было ответов, его можно удалить.