Отображение данных LongBlob как изображения

I have the following code to read blob data & display the result as an image. But I'm getting the error java.lang.IllegalStateException: getWriter() has already been called for this response.

while (rs2.next()) {
    Blob image = null;
    byte[] imgData = null;
    j++;
    qPaperOptions = rs2.getString(1);
    int qDetailId = rs2.getInt(2);
    image = rs2.getBlob(5);

    ServletOutputStream sout = response.getOutputStream();
   //o.close();
   //imgData = image.getBytes(1,(int)image.length());
   //Blob cnt_data=rs2.getBlob("cimg.ctn_data");
    if (image != null) {
       //imgData = image.getBytes(1,(int)image.length());
        response.setContentType("image/gif");
        InputStream in = image.getBinaryStream();
        int length = (int) image.length();
        int bufferSize = 1024;
        byte[] buffer = new byte[bufferSize];
        while ((length = in.read(buffer)) != -1) {
            sout.write(buffer, 0, length);
        }
    }
}

Что я могу сделать, чтобы решить эту ошибку?

3
nl ja de
любезно поделиться сценарием DDL таблицы
добавлено автор KNU, источник

1 ответы

Какая строка бросает исключение? В общем, код выглядит правильно. Всего несколько идей: Может быть, вы повторяете этот код дважды (два результата или больше в наборе результатов)? Также попробуйте настроить contentType перед тем, как получить выходной поток.

0
добавлено
Вы отправляете весь метод, который вызывает это? Может быть, вы отправляете что-то в ответ, прежде чем пытаться получить OutputStream?
добавлено автор Andres Olarte, источник
в этой строке im получает errorServletOutputStream sout = response.getOutputStream ();
добавлено автор Shafiq, источник
pro.jvm
pro.jvm
3 503 участник(ов)

Сообщество разработчиков Java Scala Kotlin Groovy Clojure Чат для нач-их: @javastart Наш сайт: projvm.com projvm.ru Наш канал: @proJVM Вакансии: @jvmjobs Конфы: @jvmconf

Java & Co
Java & Co
2 370 участник(ов)

Можно обсуждать с матом и без всё, что касается жабы, вплоть до холиваров. НЕ ИМЕЕТ ОТНОШЕНИЯ К САЙТУ JAVARUSH.RU ПРАВИЛА - https://t.me/javarush/75723 Вакансии сюда - https://telegram.me/joinchat/B7IzvUCnfo6d8t3yIxKguQ По вопросам - @thedude

learn.java
learn.java
1 888 участник(ов)

Чат для начинающих и не только Статистика: https://combot.org/chat/-1001083535868 Основной чат - @jvmchat

Java Underground
Java Underground
169 участник(ов)

https://vk.com/javatutorial

Javanese Questions
Javanese Questions
109 участник(ов)

Чат предназначен для обмена знаниями строго в формате в вопрос-ответ. Тема — Java, Kotlin и Android. Вопрос должен быть предварительно прогуглен, понятно и грамотно сформулирован, помечен хэштегами. Ответ — тем более. Куски кода размером в несколько строк можно писать прямо здесь, для больших кусков кода стоит использовать http://gist.github.com/, http://pastebin.com/, https://codeshare.io/ или любой аналогичный сервис. В некоторых случаях можно прикреплять скриншоты. Стикеры и гифки запрещены. Дополнять и уточнять вопросы и ответы — редактированием исходного сообщения. Обсуждения должны приводить к редактированию вопроса/ответа и удаляться. По хештегам можно искать существующие вопросы и овтеты: #вопрос #ответ #git #generics #java #server #awt #javafx #swing #kotlin #anko #tornadofx #ktor #android #recyclerView #performance #arch #network #permissions #storage #async