将byte []转换为图像并在jsp上显示

时间:2016-01-01 21:27:19

标签: java hibernate jsp spring-mvc image-uploading

我正在尝试在jsp页面上显示上传的图片(现在是一个字节数组)。现在,byte []列存在于数据库中,必须转换为图像。

这就是我一直在尝试的:

jsp页面上的部分表格:

<c:forEach var="user" items="${userList}">
    <tr>
        <td>${user.fileName}</td>
        <td>
            <img src="data:image/jpg;base64,${user.imageFile}" alt="No image">
        </td>

从MultipartFile对象获取字节数组的控制器的一部分:

@RequestMapping(value = "/register", method = RequestMethod.POST)
    public ModelAndView userRegister(@ModelAttribute("user") @Valid User user, BindingResult result, ModelMap model, @RequestParam("fileData") MultipartFile fileData) throws Exception {

            if (!fileData.isEmpty() && fileData != null) {                

                byte[] bytes = fileData.getBytes();
                user.setFileName(fileData.getOriginalFilename());
                user.setImageFile(bytes);
            }
        }

如果需要任何其他信息,请告知我们。感谢。

1 个答案:

答案 0 :(得分:14)

您可以向base64imageFile添加传输User媒体资源。它将保存图像的base64编码字符串,您可以在jsp中访问该字符串,如

<img alt="img" src="data:image/jpeg;base64,${user.base64imageFile}"/>

在您的方法中,您应该进行编码,例如

@RequestMapping(value = "/register", method = RequestMethod.POST)
    public ModelAndView userRegister(@ModelAttribute("user") @Valid User user, BindingResult result, ModelMap model, @RequestParam("fileData") MultipartFile fileData) throws Exception {
        if (!fileData.isEmpty() && fileData != null) {                
            byte[] bytes = fileData.getBytes();
            user.setFileName(fileData.getOriginalFilename());
            user.setImageFile(bytes);
            byte[] encodeBase64 = Base64.encodeBase64(bytes);
            String base64Encoded = new String(encodeBase64, "UTF-8");
            user.setBase64image(base64encoded);
        }
    }

IOUtilsBase64是来自org.apache.commons的便捷工具类,不应该找到问题