Как вывести двоичный документ на основе HTML документа с помощью фильтров в Java


Это может быть немного запутанным, но у меня возникли некоторые проблемы. Моя цель состоит в том, чтобы взять входной HTML-документ, а затем обработать этот документ и использовать HTML-данные для вывода документа изображения. Например, пользователь запросит URL-адрес с некоторым действием=png в строке запроса, а затем фильтр будет вызван для URL-адреса и выходного документа изображения.

Я перепробовал все, но в моей среде (Websphere)я могу выводить только один тип. Если тип ввода-text / html, то я могу выводить только текстовый документ, я не могу вывести двоичный документ. Почему? Потому что я каждый раз получаю незаконное исключение штата.

[1/29/09 17:59:57:576 EST] 00000020 SystemErr R java.яз..IllegalStateException: SRVE0209E: Writer уже получен [1/29/09 17:59:57:576 ЭСТ] 00000020 SystemErr R в ком.корпорация IBM.с WS.webcontainer.СРТ.SRTServletResponse.getOutputStream(SRTServletResponse.Ява:505)

Я использую псевдокод, чтобы не раскрывать весь мой код:

<filter>
    <filter-name>TestFilter</filter-name>
    <filter-class>
        com.util.TestFilter
    </filter-class>
</filter>

<filter-mapping>
    <filter-name>TestFilter</filter-name>
    <url-pattern>/index_test2.html</url-pattern>
</filter-mapping>

Код класса-оболочки по существу таков:

public class ContentCaptureServletResponse extends HttpServletResponseWrapper { 
    private ByteArrayOutputStream contentBuffer;
    private PrintWriter writer; 
    public PrintWriter getWriter() throws IOException {
        if (writer == null) {
            contentBuffer = new ByteArrayOutputStream();
            writer = new PrintWriter(contentBuffer);
        }       
        return writer;
    }   
    public String getContent(){
        try {
            writer = getWriter();
        } catch (IOException e) {           
            e.printStackTrace();
        }
        writer.flush();
        String xhtmlContent = new String(contentBuffer.toByteArray());                 
        System.out.println(xhtmlContent);                
        return xhtmlContent; 
    }
}

А код фильтра таков:

public void doFilter(ServletRequest req, ServletResponse resp, FilterChain filterChain) throws IOException, ServletException {

        HttpServletRequest request = (HttpServletRequest) req;
        HttpServletResponse response = (HttpServletResponse) resp;
        final String renderType = request.getParameter("R"); 
        final String renderClassName = request.getParameter("C");
        if ((renderType != null) && (renderClassName != null)) {
            try {
                this.setFilterChain(filterChain);
                response.setContentType("image/png");
                PrintWriter out = response.getWriter();                             
                // I call getWriter but not BOTH!
                //response.getOutputStream();               
                response.getWriter();

                // Build up the HTML document into a string.
                    CaptureResponse capContent = new CaptureResponse(response);            
                this.mainFilterChain.doFilter(req, );
                String myString = capHtmlContent.getContent();

                // What I really want to do here is output an output stream
                // so I can write a binary image
                processStr(myString);
                response.getOutputStream();             
                response.write(binaryimage)

            } catch (Exception e) {            
                e.printStackTrace();
            }
            // No data will be output to the user.
        } else {
            filterChain.doFilter(request, response);
        }  // End of if-else        
    } // End of the method.

Код работает, если я хочу взять какой-то входной html-текстовый документ. Я предполагаю, что из-за открытого потока printwriter. Но у меня возникли проблемы с переходом на другой формат. В основном, потому что я не могу вызвать ответ.getOutputStream ()

2 4

2 ответа:

Проблема, похоже, заключается в том, что вы открываете средство записи ответов перед упаковкой ответа.

Похоже, что вы должны быть в состоянии сделать:

this.setFilterChain(filterChain);
CaptureContent capContent = new CaptureResponse(response);
doFilter()
process();
response.setContentType("image/png");
response.getOutputStream().write(imagedata);

Вы определенно не можете безопасно открыть как Writer, так и OutputStream

У меня нет опыта работы с Websphere, но одна общая проблема заключается в том, что вы пытаетесь манипулировать заголовком HTTP после того, как вы уже решили отправить тело-как только веб-сервер начал доставлять содержимое, вы больше не можете обновлять заголовки, так как они уже были отправлены.

Возможно, вам нужно просмотреть документацию и примеры. Например, я не понимаю, почему вы называете ответом.получить* (), фактически не глядя на результат. Вы уверены, что это необходимо, или это так потому что ты урезал свой код?

Ура!, Volker