Search code examples
javaimagebase64apache-poidata-uri

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


How to add Image with data url in excel using Apache-poi.

Solution Converts inline image rendered on browser to byte-array


Solution

  • 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();
    }