Как отобразить изображение из базы данных mysql с помощью spring mvc

Я храню изображение типа BLOB в базе данных MySQL, используя Spring MVC для класса элемента Item (itemId, itemName, itemPrice, itemContent, itemImage). Я успешно сохранил изображение в базе данных, но когда я пытаюсь отобразить его в моем jsp, оно показывает что-то двоичное, например [B @7fb0c025.

Как я могу отобразить правильное изображение в JSP (изображение хранится в таблице базы данных MySQL)

Мой модельный класс:

@Entity
@Table(name="item")
public class Item {

@Id
@Column(name="ItemId")
@GeneratedValue
private Integer itemId;

@Column(name="ItemName")
private String itemName;

@Column(name="ItemContent")
private String itemContent;
/*
@Column(name="ItemImage")
private ByteArray ItemImage;
*/
@Column(name="ItemPrice")
private int itemPrice;

@Column(name="ItemImage")
private byte[] itemImage;

"addItem.jsp" для добавления атрибутов элемента вместе с изображением в базу данных.

<form:form modelAttribute="itemAttribute" enctype="multipart/form-data" method="POST" action="${Url}">
<table>

    <tr>
        <td><form:label path="itemId"></form:label></td>
        <td><form:input path="itemId" type="hidden"/></td>
    </tr>

    <tr>
        <td><form:label path="itemName">ItemName:</form:label></td>
        <td><form:input path="itemName"/></td>
    </tr>
    <tr>
        <td><form:label path="itemPrice">ItemPrice:</form:label></td>
        <td><form:input path="itemPrice"/></td>
    </tr>
    <tr>
        <td><form:label path="itemContent">ItemContent:</form:label>
        <td><form:input path="itemContent"/>
    </tr>
    <tr>
        <form:label for="itemImage" path="itemImage">itemImage:</form:label>
        <form:input path="itemImage" type="file" />
    </tr>
</table>

<input type="submit" value="Save" />
</form:form>

Страница JSP для отображения атрибутов элемента вместе с изображением.                        CategoryId:                  

    <tr>
        <td><form:label path="categoryName">CategoryName:</form:label></td>
        <td><form:input path="categoryName"/></td>
    </tr>
</table>
<input type="submit" value="Save" />

<table width: 100%; text-align:center">
<tr>
    <th>ItemId</th>
    <th>ItemName</th>
    <th>ItemPrice</th>
    <th>ItemFeatures</th> 
    <th>Edit</th>
    <th>Delete</th>
    <th>ItemImage</th>
</tr>
<tbody>


    <c:forEach items="${categoryAttribute.item}" var="item">
    <tr>
            <c:url var="editCUrl" value="/item/edit?bid=${categoryAttribute.categoryId}&cid=${item.itemId}" />
            <c:url var="deleteCUrl" value="/item/delete?id=${item.itemId}" />
            <td><c:out value="${item.itemId}" /></td>
            <td><c:out value="${item.itemName}"/></td>
            <td><c:out value="${item.itemPrice}"/></td>
            <td><c:out value="${item.itemContent}"/></td>
            <td><a href="${editCUrl}">EditItem</a></td>
            <td><a href="${deleteCUrl}">DeleteItem</a></td>
            <td><c:out value="${item.itemImage}"/></td>
    </tr>   
    </c:forEach>

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

Ответ 1

Наконец-то я смогу отобразить изображение на моем jsp. что я сделал.

Я отдельно создал контроллер вроде этого.

@Controller
@RequestMapping("/myImage")
public class ImageController {

@Resource(name="categoryService")
private CategoryService categoryService;

@Resource(name="itemService")
private ItemService itemService;

@RequestMapping(value = "/imageDisplay", method = RequestMethod.GET)
  public void showImage(@RequestParam("id") Integer itemId, HttpServletResponse response,HttpServletRequest request) 
          throws ServletException, IOException{


    Item item = itemService.get(itemId);        
    response.setContentType("image/jpeg, image/jpg, image/png, image/gif");
    response.getOutputStream().write(item.getItemImage());


    response.getOutputStream().close();

и в jsp я сделал это

<img src="/Project1/myImage/imageDisplay?id=${item.itemId}"/>

И изображение было успешно отображено.

Ответ 2

Я написал код ниже в моем контроллере, и он работает нормально для меня.

В моем проекте Пользователь содержит объект профиля с фотографией @Lob. Измените этот код в соответствии с вашими атрибутами.

    byte[] encodeBase64 = Base64.encode(user.getProfile().getPhoto());
    String base64Encoded = new String(encodeBase64, "UTF-8");
    mav.addObject("userImage", base64Encoded );

В файле JSP я написал код

<img src="data:image/jpeg;base64,${userImage}" />

Для этого вам понадобится баночка с общим кодеком.

Также вы можете использовать собственный тег для показа изображения.

Ответ 3

Еще одна вещь, которую вы можете сделать для отображения изображения в jsp из базы данных. предположим, что вам нужно отображать изображения всех пользователей в jsp. для этого вы можете создать свой собственный тег justl custome, который содержит код для преобразования байтового изображения в образ base64.

здесь в моем проекте изображение находится в классе профиля

i.e user.getProfile(). getPhoto()

    package com.spring.tags;

import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.text.SimpleDateFormat;
import java.util.Date;

import javax.servlet.jsp.JspException;
import javax.servlet.jsp.JspWriter;
import javax.servlet.jsp.tagext.SimpleTagSupport;
import javax.servlet.jsp.tagext.TagSupport;

import org.apache.commons.codec.base64.Base64;

public class UserImage extends SimpleTagSupport {

    private byte[] usrImage;

    public void setUsrImage(byte[] usrImage) {
        this.usrImage = usrImage;
    }

@Override
    public void doTag() throws JspException, IOException {
        System.out.println("tag lib");
        try {
            JspWriter out = getJspContext().getOut();
            if (usrImage != null && usrImage.length > 0) {
                byte[] encodeBase64 = Base64.encode(usrImage);
                String base64Encoded = new String(encodeBase64, "UTF-8");
                out.print("data:image/jpeg;base64,"+base64Encoded);

            }
        } catch (Exception e) {
            throw new JspException("Error: " + e.getMessage());     }
    }   
}

создать файл tld в WebContent. Я создаю файл в папке taglib

<?xml version="1.0" encoding="UTF-8"?>
<taglib version="2.0" xmlns="http://java.sun.com/xml/ns/j2ee" 
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
  xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee web-jsptaglibrary_2_0.xsd">
  <tlib-version>1.0</tlib-version>
    <short-name>ui</short-name>
    <uri>/taglib/userimage</uri>
    <tag>
        <name>image</name>
        <tag-class>com.spring.tags.UserImage</tag-class>
        <body-content>empty</body-content>
        <info>This Tag Displayes current user profile image</info>
        <attribute>
            <name>usrImage</name>
            <required>true</required>
            <description>Provide a display format</description>
            <rtexprvalue>true</rtexprvalue>
        </attribute>
    </tag>
</taglib>

Теперь вы можете написать код в jsp для отображения изображения.

<img src="<ui:image usrImage='${user.profile.photo}' />

Каждый раз, когда нет необходимости конвертировать изображение в контроллер, просто передайте изображение байта в jsp, и наш тег custome преобразует изображение в байты и отправит его на страницу просмотра.

Примечание: включить файл тегов custome в файл jsp

<%@ taglib uri="/taglib/userimage.tld" prefix="ui"%>

Ответ 4

Однако я использовал собственный запрос для получения ArrayList & lt;>, поэтому я не мог использовать метод setter и getter в своем контроллере для получения байтов для кодирования в Base64, вместо этого я создал поле @Transient в своем классе Dao для кодирования в base64 и это сработало.

В моем дао

    @Transient
private String imgUtility;


//getter method for encoding
public String getImgUtility() throws UnsupportedEncodingException {

    byte[] encodeBase64 = Base64.encodeBase64(getImage());
     String base64Encoded = new String(encodeBase64, "UTF-8");              
    return base64Encoded;
}

и в представлении JSP вы можете сделать это

<img src="data:image/jpeg;base64,${tempCust.imgUtility}"/>