Expand my Community achievements bar.

SOLVED

How to Read & Display Image File in AEM 6.5

Avatar

Level 2

Hi All,

In AEM 6.5 I am trying to read the jcr:data (Binary) from jcr:content and convert it to base64 to display the image in frontend page level (HTML).

I can read the jcr:data and converted to base64 but when I am trying to display the same base64 image in HTML it is not properly loaded & When i try to decode the generated encrypted string online image is not properly loaded.

 

Kindly check below screenshots for your reference.

Does anyone have any ideas or other things I can check for as to why this would not work?

 

I have written the following java code to read the jcr:data from jcr:content and convert it to base64 to display the image in frontend page level (HTML).

 

Ashok884_0-1640854490061.png

 

 

 

And I got the base64 string as below.

 

""

 

When I am trying to display the same base64 image in HTML it is not properly loaded as showing below.

Ashok884_1-1640854489787.png

 

 

1 Accepted Solution

Avatar

Correct answer by
Community Advisor

Hi @Ashok884, could you please try to modify your code like below:

 

import org.apache.commons.io.IOUtils;

// ... your code

InputStream is = jcnode.getProperty(CommonConstant.JCR_DATA).getBinary().getStream();

String mimeType = jcnode.getProperty(CommonConstants.JCR_MIME_TYPE).getString();

// IOUtils.toByteArray(is) will produce base64 string representation
teaser3x2 = "data:" + mimeType + ";base64" +
Base64.getEncoder().encodeToString(IOUtils.toByteArray(is));

 

View solution in original post

1 Reply

Avatar

Correct answer by
Community Advisor

Hi @Ashok884, could you please try to modify your code like below:

 

import org.apache.commons.io.IOUtils;

// ... your code

InputStream is = jcnode.getProperty(CommonConstant.JCR_DATA).getBinary().getStream();

String mimeType = jcnode.getProperty(CommonConstants.JCR_MIME_TYPE).getString();

// IOUtils.toByteArray(is) will produce base64 string representation
teaser3x2 = "data:" + mimeType + ";base64" +
Base64.getEncoder().encodeToString(IOUtils.toByteArray(is));