Получить несколько изображений из базы данных

Я пытаюсь получить несколько изображений из базы данных и отобразить их с помощью страницы JSP, я пробовал, но не получил идеальной логики для извлечения нескольких изображений из базы данных.

Ниже приведен код для получения одного изображения, пожалуйста, помогите получить несколько изображений.

Я использую базу данных mysql

мой код сервлета:

package com.Image;
import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.tomcat.util.codec.binary.Base64;


@WebServlet("/ImageRetrieve")
public class ImageRetrieve extends HttpServlet {
    static {
        try {
            Class.forName("com.mysql.jdbc.Driver");
        } catch (ClassNotFoundException e) {

            e.printStackTrace();
        }
    }
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException 
    {   Connection con = null;
    PreparedStatement ps = null;
ResultSet rs = null;
        try {
            con = DriverManager.getConnection("jdbc:mysql://localhost:3306/database1", "root", "vicky");
            ps = con.prepareStatement("select frontimage from album ");
            rs=ps.executeQuery();
                    if (rs.next()) {
                        byte[] fi = rs.getBytes("frontimage");

                        String FI = new String(Base64.encodeBase64(fi), "UTF-8");
                        request.setAttribute("FIS", FI);
                        RequestDispatcher rd=request.getRequestDispatcher("RetrieveImage.jsp");  
                        rd.forward(request, response);  
                    }

            } catch (SQLException e) {
                throw new ServletException("Something failed at SQL/DB level.", e);
            }
        }


    }

мой код jsp:

<%@ page language = "java" contentType = "text/html; charset=ISO-8859-1"
    pageEncoding = "ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv = "Content-Type" content = "text/html; charset=ISO-8859-1">
<title>Display Image</title>
</head>
<body>
<div>THE DISPLAY</div>
<div >
<img src = "data:image/png;base64,${requestScope['FIS']}" style = "width:50px; height:50px"/>

</div>

</body>
</html>
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
0
0
624
2

Ответы 2

Ваша проблема заключается в операторе if if (rs.next()), который выполняется только один раз независимо от количества результатов в ResultSet. Поскольку оператор if возвращает истину, если в ResultSet есть какое-либо количество результатов, первое изображение ResultSet сохраняется, и код переходит к следующему, поскольку условие if было выполнено. Код сделал именно то, что вы ему сказали. Изменение оператора if на while (rs.next()) будет проходить через весь ResultSet, сохраняя каждое изображение в вашем предопределенном массиве.

спасибо за ваше предложение, если я использую «while (rs.next ())», как я могу получить эти изображения, например «byte [] fi = rs.getBytes (« frontimage »);»

VIKAS DUBBAKA 13.09.2018 18:36

Захватите изображения следующим образом: List<String> images = new ArrayList<>();. Используйте этот список изображений в том, что теперь будет вашим циклом while while (rs.next()) вместо массива byte [] при сохранении данных таблицы из ResultSet.

J.Wright 13.09.2018 18:48

, спасибо, пришлите, пожалуйста, как перебирать список на странице jsp, пожалуйста, я новичок в ИТ-секторе, я нахожусь на стадии обучения

VIKAS DUBBAKA 13.09.2018 18:55

Похоже, что @Andrew S меня опередил, но вот пример реализации из другого потока SO: stackoverflow.com/questions/20789207/…

J.Wright 13.09.2018 19:29

Спасибо тебе за помощь

VIKAS DUBBAKA 13.09.2018 19:32
if (rs.next()) {
    ...
}

получит только первый байт [] от rs. Измените это на цикл while, чтобы получить каждый из них:

while (rs.next()) {
    ...
}

Но вам нужен контейнер, например List, для их хранения:

List<String> images = new ArrayList<>();
while (rs.next()) {
    ... 
    images.add(FI)
}

Затем после цикл, установите атрибут List и вперед:

request.setAttribute("FIS", images);
RequestDispatcher rd= ...;  
rd.forward(request, response);

И в JSP переберите FIS (который теперь является списком), чтобы отобразить каждый из них.

спасибо, пришлите, пожалуйста, как перебирать список на странице jsp, пожалуйста, я новичок в ИТ-секторе, я новичок

VIKAS DUBBAKA 13.09.2018 18:42
Вот пример.
Andrew S 13.09.2018 18:51

спасибо, я перейду к этому примеру

VIKAS DUBBAKA 13.09.2018 18:56

Другие вопросы по теме