Имам jsp, в който за всеки ред от таблицата трябва да покажа изображението, присъстващо в базата данни. Извличам всички данни от реда на таблицата от базата данни, включително изображението като Blob, и го съхранявам в bean. Изображението се съхранява в bean като байтов масив по следния начин:
photo = rs.getBlob("PHOTO");
photoByteArray = photo.getBytes(1, (int)photo.length());
Докато преглеждате списъка с бобове в jsp, атрибутът src сочи към сървлет като този:
<img class="img" width="55" height="50" src="displayThumbnail?photoData=${part.photoData}">
който обслужва изображението, както е показано по-долу, но те не се показват, но при отстраняване на грешки масивът от байтове изглежда има данни.
protected void processRequest(HttpServletRequest request, HttpServletResponse response) throws IOException {
response.setContentType("image/jpeg");
OutputStream o = response.getOutputStream();
String photoDataStr = request.getParameter("photoData");
byte[] photoData = null;
if(photoDataStr != null) {
photoData = photoDataStr.getBytes();
}
o.write(photoData);
o.close();
}
Изображението обаче не се показва. Сега, ако направя заявка в базата данни за всяко отделно изображение, както е показано по-долу, изображенията се показват добре в този случай.
protected void processRequest(HttpServletRequest request, HttpServletResponse response) {
PreparedStatement pstmt = null;
ResultSet rs = null;
Connection conn = null;
try {
if(conn == null) {
conn = open();
}
pstmt = conn.prepareStatement("select photo from PART_PHOTOS where id = ?");
String id = request.getParameter("id");
pstmt.setString(1, id);
rs = pstmt.executeQuery();
if (rs.next()) {
Blob b = rs.getBlob("photo");
response.setContentType("image/jpeg");
response.setContentLength((int) b.length());
InputStream is = b.getBinaryStream();
OutputStream os = response.getOutputStream();
byte buf[] = new byte[(int) b.length()];
is.read(buf);
os.write(buf);
os.close();
is.close();
}
} catch (Exception ex) {
System.out.println(ex.getMessage());
ex.printStackTrace();
} finally {
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
rs = null;
}
if (pstmt != null) {
try {
pstmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
pstmt = null;
}
//check if it's the end of the loop
if (conn != null) {
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
}
conn = null;
}
}
}
Ще съм много благодарен, ако някой може да даде препоръки около същото.