【问题标题】:Retrieve multiple images from database [duplicate]从数据库中检索多个图像[重复]
【发布时间】:2018-09-13 16:04:16
【问题描述】:

我正在尝试从数据库中检索多个图像并使用 JSP 页面显示它们,我尝试但没有得到完美的逻辑来从数据库中检索多个图像。

以下是检索单张图片的代码,请帮忙检索多张图片

我正在使用mysql数据库

我的 servlet 代码:

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>

【问题讨论】:

    标签: java mysql database jsp servlets


    【解决方案1】:
    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页面中迭代列表,请我是IT部门的新手,我是初学者
    • Here's 一个例子。
    • 谢谢我会用那个例子来说明
    【解决方案2】:

    您的问题出在 if 语句 if (rs.next()) 中,无论 ResultSet 中的结果数量如何,它只执行一次。因为如果 ResultSet 中有任意数量的结果,则 if 语句返回 true,因此存储 ResultSet 的第一个图像并且代码继续前进,因为 if 条件已经满足。代码完全按照您的要求完成了。将 if 语句更改为 while (rs.next()) 将遍历整个 ResultSet,将每个图像保存到预定义的数组中。

    【讨论】:

    • 感谢您的建议,如果我使用 "while(rs.next())" 我如何获取这些图像,例如 "byte[] fi = rs.getBytes("frontimage");"
    • 像这样捕获图像:List&lt;String&gt; images = new ArrayList&lt;&gt;();。在存储来自 ResultSet 的表数据时,在您的 while 循环 while (rs.next()) 中使用此图像列表代替您的 byte[] 数组。
    • ,谢谢,请您发送如何在jsp页面中迭代列表,请我是IT部门的新手,我处于学习阶段
    • 看起来@Andrew S 打败了我,但这是另一个 SO 线程的示例实现:stackoverflow.com/questions/20789207/…
    • 谢谢您的帮助
    猜你喜欢
    • 2020-03-30
    • 2011-04-20
    • 2023-03-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-01-01
    相关资源
    最近更新 更多