Я пытаюсь получить несколько изображений из базы данных и отображать их с помощью 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>
Ваша проблема находится в if-statement if (rs.next())
который выполняется только один раз, независимо от количества результатов в ResultSet. Поскольку if-statement возвращает true, если в ResultSet есть какое-то количество результатов, первое изображение ResultSet сохраняется и код перемещается, потому что условие if выполнено. Код сделал именно то, что вы сказали ему сделать. Изменение if-утверждения while (rs.next())
будет проходить через весь ResultSet, сохраняя каждое изображение в вашем предопределенном массиве.
if (rs.next()) {
...
}
получит только первый байт [] от rs
. Измените это на цикл while, чтобы получить каждый из них:
while (rs.next()) {
...
}
Но для этого вам нужен контейнер, например Список для их хранения:
List<String> images = new ArrayList<>();
while (rs.next()) {
...
images.add(FI)
}
Затем после цикла установите атрибут List и forward on:
request.setAttribute("FIS", images);
RequestDispatcher rd= ...;
rd.forward(request, response);
И в JSP, итерации по FIS (который теперь является списком) для отображения каждого из них.
List<String> images = new ArrayList<>();
, Используйте этот список изображений в том, что теперь будет вашим цикломwhile (rs.next())
вместо массива byte [] при хранении данных таблицы из ResultSet.