EasyExcel导出压缩图片,判断图片url是否可用

EasyExcel导出压缩图片,判断图片url是否可用

如果有关于EasyExcel导出的其他相关问题,可以查看历史文章,这次主要对EasyExcel导出图片做进一步完善,导出压缩图片

1.压缩图片工具类

	/**
     * url转成图片并压缩
     */
    public static URL downloadAndCompress(String url, float quality) throws IOException {
        boolean isExist = checkImageExist(url);
        if (!isExist) {
            return new URL("");
        }

        File file = null;
        InputStream inputStream = null;
        FileOutputStream fos = null;
        try {
            file = File.createTempFile("image", "jpg");
            URL urlFile = new URL(url);
            inputStream = urlFile.openStream();
            fos = new FileOutputStream(file);

            byte[] bytes = new byte[10240];
            int bytesRead;
            while ((bytesRead = inputStream.read(bytes, 0, 10240)) != -1) {
                fos.write(bytes, 0, bytesRead);
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            try {
                if (null != fos) {
                    fos.close();
                }
                if (null != inputStream) {
                    inputStream.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
        }

        // 指定压缩图片的方式、参数等
        ImageWriter imageWriter = ImageIO.getImageWritersByFormatName("jpg").next();
        ImageWriteParam imageWriteParam = new JPEGImageWriteParam(null);
        imageWriteParam.setCompressionMode(ImageWriteParam.MODE_EXPLICIT);
        imageWriteParam.setCompressionQuality(quality);
        imageWriteParam.setProgressiveMode(ImageWriteParam.MODE_DISABLED);

        ColorModel colorModel = ImageIO.read(file).getColorModel();
        imageWriteParam.setDestinationType(new javax.imageio.ImageTypeSpecifier(colorModel, colorModel.createCompatibleSampleModel(32, 32)));
        FileOutputStream out;
        if (!file.exists()) {
            throw new FileNotFoundException("文件不存在");
        } else {
            BufferedImage bufferedImage = ImageIO.read(file);
            out = new FileOutputStream(file);
            imageWriter.reset();
            imageWriter.setOutput(ImageIO.createImageOutputStream(out));
            imageWriter.write(null, new IIOImage(bufferedImage, null, null), imageWriteParam);
            out.flush();
            out.close();
        }
        return file.toURI().toURL();
    }
  1. 判断图片是否可用
	/**
     * 判断图片数据是否正常
     * @param urlString
     */
    public static boolean checkImageExist(String urlString) {
        URL url;
        URLConnection urlConnection;
        try {
            url = new URL(urlString);
            urlConnection = url.openConnection();
            int status = ((HttpURLConnection) urlConnection).getResponseCode();
            if (status == 200) {
                return true;
            }
        } catch (Exception e1) {
            System.out.println("图片不存在!");
        }
        return false;
    }
  1. 我这里需要返回URL(上面做了类型转换:file.toURI().toURL()),可以根据需要返回对应的类型
	// 实体类字段
	@ExcelProperty(value = "Event Photo", converter = UrlImageConverter.class)
    private URL imagePath;
try {
   URL url = ImageUtil.downloadAndCompress(event.getEventPhoto(), 0.1f);
   exportExcelVo.setImagePath(url);
} catch (IOException e) {
   e.printStackTrace();
}

因为有些时候返回的远程图片url无法正常打开,导致在写入excel时会报异常,所以就先判断url是否可用再写入。

  • 10
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,我并不知道您的具体需求和情境。不过,如果您想在使用 easyexcel 导出 excel 文件时将图片插入到单元格中,可以尝试以下步骤: 1. 在需要插入图片的单元格中,使用 `ByteArrayOutputStream` 将图片转换成字节数组。 2. 在使用 easyexcel 导出 excel 文件时,通过 `WriteHandler` 接口中的 `cell` 方法,将字节数组插入到单元格中。 以下是一个示例代码: ```java public class ImageWriteHandler implements WriteHandler { private byte[] imageBytes; public ImageWriteHandler(byte[] imageBytes) { this.imageBytes = imageBytes; } @Override public void cell(int i, CellData cellData, Cell cell) { if (cellData.getType() == CellDataTypeEnum.STRING) { Drawing<?> drawing = cell.getSheet().createDrawingPatriarch(); ClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0, cell.getColumnIndex(), cell.getRowIndex(), cell.getColumnIndex() + 1, cell.getRowIndex() + 1); drawing.createPicture(anchor, cell.getSheet().getWorkbook().addPicture(imageBytes, Workbook.PICTURE_TYPE_PNG)); } } @Override public void row(int i, RowData rowData) { } @Override public void sheet(int i, Sheet sheet) { } @Override public void workbook(List<Sheet> list, Workbook workbook) { } } ``` 然后,在使用 easyexcel 导出 excel 文件时,将 `ImageWriteHandler` 对象传递给 `ExcelWriter` 的 `registerWriteHandler` 方法即可。 ```java ExcelWriter writer = EasyExcel.write(outputStream).build(); Sheet sheet = new Sheet(1, 0); List<List<Object>> data = new ArrayList<>(); // 添加数据和图片 data.add(Arrays.asList("Name", "Age", "Image")); data.add(Arrays.asList("John", 25, new ImageWriteHandler(imageBytes))); writer.write(data, sheet); writer.finish(); ``` 请注意,以上代码仅供参考,并且仅适用于在单元格中插入静态图片的情况。如果您需要在单元格中插入动态图像或其他更高级的功能,可能需要使用其他库或更复杂的技术实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值