my model store image described with file name (as String) and data (as byte array). I use Hibernate and here's my model:
@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;
}
}
But I want to display my stored image, on web site like:
<img src="${image.data}" alt="car_image"/>
How could I do that?
Should I write controller that serve requests for images?
Any code examples?
UPDATE
<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>
You can display image by keeping image name in request scope and fetch it by its name JSTL. String imageName = "test. jpg"; request.
It is generally preferred to hide the . css/ . js files from direct public access by placing them into the main/java/webapp folder instead of the WEB-INF.
You cannot do it like this. Your image must be exposed somehow via normal URL. In Spring MVC create a controller that returns an image (raw data) under particular 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();
}
Now useit in your JSP page. This is how HTTP/HTML work:
<img src="/yourApp/imageController/42.png" alt="car_image"/>
In Spring MVC before 3.1 you might need to do a little bit more coding on controller side. But the principle is the same.
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);
Now use it in your JSP page following as
<img src="data:image/jpeg;base64,${image}" alt="..." width="200" height="200">`
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With