微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

elementui中展示后台传回来的多个图片流

1. 前端
如果返回一个图片的话就可以,直接返回,img标签可以直接解析,但是如果返回多个图片,就解析不成功,需要转成base64编码(可以在前台转,也可以在后台进行,此处在java代码转化),再进行src解析
 <!--图片展示-->
    <el-dialog
      title="凭证图"
      :visible.sync="dialogVisiblesImage"
      width="50%">
      <div
        v-for="item in imgurlMany"
        :key="item.id">
        <img
          :src="item.url"
          width="100%"
          style="margin:0 auto">
      </div>
    </el-dialog>
data:数据
imgurlMany: [],
dialogVisiblesImage: false,

方法:
  // 返回结果是图片
            detailImages(row.id).then(response => {
              this.imgurlMany = response.data.map(item => {
                return {
                  url: item.body
                }
              })
              this.dialogVisiblesImage = true
            }).catch(error => {
              this.$message.error(error.message)
            })
2.java
public HttpResult<List<ResponseEntity<String>>> detailImages(@RequestBody String id) {
        List<ResponseEntity<String>> responseEntities = groupPolicyrenewalService.detailImage(id);
        return HttpResultUtil.success("查询成功",responseEntities);
    }


@Override
public List<ResponseEntity<String>> detailImage(String groupId) {
    List<ResponseEntity<String>> responseEntityList = new ArrayList<>();
    //此处返回的是多个图片,此处只有一个修改使用
       
        File file = new File(path);

        HttpHeaders headers = new HttpHeaders();
        String fname = fileInfodo.getFilename() + "." + fileInfodo.getFiletype();

        try {
            headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);
            headers.set("fileName", URLEncoder.encode(fname, "utf-8"));
            String result = "data:image/jpg;base64,"
                    + new BASE64Encoder().encode(org.apache.commons.io.FileUtils.readFiletoByteArray(file));
            ResponseEntity<String> responseEntity = new ResponseEntity<>(result, headers, HttpStatus.OK);
            responseEntityList.add(responseEntity);
        } catch (IOException e) {
            e.printstacktrace();
            throw new RRException("文件加载失败!");
        }
  
    return responseEntityList;
}

// 主要代码

String result = "data:image/jpg;base64,"
        + new BASE64Encoder().encode(org.apache.commons.io.FileUtils.readFiletoByteArray(file));
把图片的file转成base64编码

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐