在不使用文件输入流的情况下使用 poi 在 excel 中添加带有数据 url 的图像

Add Image with data url in excel using poi without using File Input Stream

如何使用 Apache-poi 在 excel 中添加包含数据 url 的图像。

解决方案将在浏览器上呈现的内联图像转换为字节数组

public void generateSpreadsheet() {

    Workbook wb = new XSSFWorkbook();
    XSSFSheet sheet1 = null;
    HttpSession session = ServletUtil.getInstance().getSession();
    String pngImageURL = "...";//data-uri

    sheet1 = (XSSFSheet) wb.createSheet("ExcelName");

    //Method1 for data-uri using org.apache.commons.codec.binary.Base64 library
    String encodingPrefix = "base64,";
    int contentStartIndex = pngImageURL.indexOf(encodingPrefix) + encodingPrefix.length();
    byte[] imageData1 = org.apache.commons.codec.binary.Base64.decodeBase64(pngImageURL.substring(contentStartIndex));//workbook.addPicture can use this byte array

    //Alternate Method2 for data-uri using javax.xml.bind 
    // Read from a Data URL
    byte[] imagedata2 = DatatypeConverter.parseBase64Binary(pngImageURL.substring(contentStartIndex)); //workbook.addPicture can use this byte array

    //Alternate Method3 for Image File using FileInputStream
    try {
        InputStream is = new FileInputStream("C://Users//Desktop//downloadpngImage.png");
        byte[] bytes = IOUtils.toByteArray(is);//workbook.addPicture can use this byte array
        } catch (FileNotFoundException e) {}
        catch (IOException e) {}

    //code for adding image to excel starts
    int pictureIdx = wb.addPicture(imageData1, wb.PICTURE_TYPE_PNG);

    // Create the drawing patriarch. This is the top level container for all shapes. 
    Drawing drawing = sheet1.createDrawingPatriarch();

    //add a picture shape
    CreationHelper helper = wb.getCreationHelper();
    ClientAnchor anchor = helper.createClientAnchor();
    //set top-left corner of the picture,
    //subsequent call of Picture#resize() will operate relative to it
    anchor.setCol1(2);
    anchor.setCol2(3);
    anchor.setRow1(3);
    anchor.setRow2(4);

    Picture pict = drawing.createPicture(anchor, pictureIdx);

    //auto-size picture relative to its top-left corner
    pict.resize();
}