Spring - отображение изображения в файле jsp
образ моего хранилища моделей, описанный с именем файла (как String) и данными (в виде массива байтов). Я использую Hibernate, и здесь моя модель:
@Entity
public class Image {
private Long id;
private String name;
private byte[] data;
@Id
@GeneratedValue
@Column(name = "IMAGE_ID")
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
@Column(nullable = false, length = 100)
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Lob
@Column(nullable = false)
public byte[] getData() {
return data;
}
public void setData(byte[] data) {
this.data = data;
}
}
Но я хочу отобразить сохраненное изображение на веб-сайте, например:
<img src="${image.data}" alt="car_image"/>
Как я могу это сделать?
Должен ли я писать контроллер, который обслуживает запросы на изображения?
Любые примеры кода?
ОБНОВЛЕНИЕ
<bean id="viewResolver"
class="org.springframework.web.servlet.view.UrlBasedViewResolver">
<property name="viewClass"
value="org.springframework.web.servlet.view.tiles2.TilesView" />
</bean>
<bean id="tilesConfigurer"
class="org.springframework.web.servlet.view.tiles2.TilesConfigurer">
<property name="definitions">
<list>
<value>/WEB-INF/configs/tiles.xml</value>
</list>
</property>
</bean>
Ответы
Ответ 1
Вы не можете сделать это так. Ваше изображение должно быть каким-то образом показано через обычный URL. В Spring MVC создайте контроллер, который возвращает изображение (необработанные данные) под определенным URL-адресом:
@RequestMapping(value = "/imageController/{imageId}")
@ResponseBody
public byte[] helloWorld(@PathVariable long imageId) {
Image image = //obtain Image instance by id somehow from DAO/Hibernate
return image.getData();
}
Теперь используйте эту страницу на JSP. Вот как работает HTTP/HTML:
<img src="/yourApp/imageController/42.png" alt="car_image"/>
В Spring MVC до 3.1 вам может потребоваться немного больше кодирования на стороне контроллера. Но принцип тот же.
Ответ 2
File file = new File("home/user/test.jpg");
FileInputStream fis=new FileInputStream(file);
ByteArrayOutputStream bos=new ByteArrayOutputStream();
int b;
byte[] buffer = new byte[1024];
while((b=fis.read(buffer))!=-1){
bos.write(buffer,0,b);
}
byte[] fileBytes=bos.toByteArray();
fis.close();
bos.close();
byte[] encoded=Base64.encodeBase64(fileBytes);
String encodedString = new String(encoded);
ModelMap map = new ModelMap();
map.put("image", encodedString);
Теперь используйте его на своей странице JSP, следуя за
<img src="data:image/jpeg;base64,${image}" alt="..." width="200" height="200">`
Ответ 3
Вам может потребоваться проверить этот пост. У меня аналогичная проблема, как и вы, и решение состоит в том, чтобы преобразовать массив байтов в строку и установить в тег img, как показано ниже,
<img src="data:image/jpg;base64,<c:out value='${bean.imageByteArrayString}'/>" />
Ответ 4
Я искал правильный ответ на пару дней, поэтому напишу для меня хороший вариант:
Мое изображение уже сохранено в базе данных:
@Entity
@Table(name="PRODUCT")
public class Product {
@Lob
@Column(name="IMG")
private byte[] img;
// setters getters etc
}
Теперь в моем классе, например ShowPicture, я должен его прочитать:
String encodedImage = Base64.encode(product.getImg());
//setters and getters encodedImage
Затем моя страница jsp:
<img src='data:image/jpg;base64,<s:property value='encodedImage'/>' alt="my image" />
Просто так!:)
Ответ 5
byte[] img = yourImgEntity.getData();
response.setContentType("image/*");
response.setHeader(HttpHeaders.CACHE_CONTROL, "no-cache");
//spring-core FileCopyUtils
FileCopyUtils.copy(img, response.getOutputStream());
// or just use codes below instead of FileCopyUtils
//response.getOutputStream().write(img);
//response.getOutputStream().flush();
//response.getOutputStream().close();
Ответ 6
Возможно, это поздно, но здесь я оставляю что-то, что служило мне, и, возможно, кто-то может помочь.
Я также использую Spring MVC и Hibernate
В модели (класс сущности) создайте переменную типа String для преобразования байта типа в String с Base64.
Я сделал это для таблицы стран, которые у меня есть со своим соответствующим флагом, и я хотел бы перечислить в таблице в представлении все страны и сторону ее флаг.
Модель (сущность)
import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
import javax.persistence.Transient;
@Entity
@Table(name = "country")
public class Country implements java.io.Serializable {
private int id;
private String name;
private byte[] flag;
private String base64; //Variable to store the conversion of a data byte type to String
@Transient //Annotation so it does not persist in the database
public String getBase64() {
//Convert the data type byte to String, store it in the variable and return it
return this.base64 = Base64.encode(this.flag);
}
public void setBase64(String base64) {
this.base64 = base64;
}
public Country() {
}
public Country(int id, String name, byte[] flag, String base64) {
this.id = id;
this.name = name;
this.flag = this.flag
this.base64 = this.base64;
}
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id", unique = true, nullable = false)
public int getId() {
return this.id;
}
public void setId(int id) {
this.id = id;
}
@Column(name = "name")
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
@Column(name = "flag")
public byte[] getFlag() {
return this.flag;
}
public void setFlag(byte[] flag) {
this.flag = flag;
}
}
Репозиторий - Реализация - это интерфейс - AbstractDao - это класс Аннотация import org.springframework.stereotype.Repository; import application.model.Country; import application.repository.dao.AbstractDao; import application.repository.dao.CountryDao; import org.hibernate.Criteria;
@Repository("countryDao")
public class CountryDaoImpl extends AbstractDao<Integer, Country> implements CountryDao {
@Override
@SuppressWarnings("unchecked")
public List<Country> listCountries() {
Criteria criteria = createEntityCriteria(); //Country.class
criteria.setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
List<Country> listCountries = criteria.list();
return listCountries;
}
}
Сервис - это интерфейс
import application.model.Country;
import application.repository.dao.CountryDao;
import application.service.dao.CountryService;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Service("countryService")
public class CountryServiceImpl implements CountryService {
@Autowired
private CountryDao countryDao;
@Override
@Transactional(readOnly = true)
public List<Country> listCountries() {
return countryDao.listCountries();
}
}
контроллер
import application.model.Country;
import application.service.dao.CountryService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping(value = "/countries")
public class CountryController {
@Autowired
private CountryService countryService;
@RequestMapping(value = "/list", method = RequestMethod.GET)
public String ListCountries(Model model) {
model.addAttribute("listcont", countryService.listCountry());
return "countries/countries"; //view
}
}
Просмотр - страны/страны .jsp
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
</head>
<body>
<h3>List Countries</h3>
<table>
<thead>
<tr>
<th>Name</th>
<th>Flag</th>
</tr>
</thead>
<tbody>
<c:forEach items="${listcont}" var="country">
<tr>
<td>${country.name}</td>
<td><img src="data:image/png;base64,${country.base64}" /></
</tr>
</c:forEach>
</tbody>
</table>
</body>
</html>